作者:十饮魂 | 来源:互联网 | 2014-04-02 11:21
最近对PHP框架比较感兴趣,毕竟PHP比JAVA来得轻巧,想与JAVA的MVC对比一番。看了一下ThinkPHP的文档,觉得写得还算不错,但是并不是那种实战型的文档,所以显得比较笼统,很多东西还是得自己摸索。
最近对PHP框架比较感兴趣,毕竟PHP比JAVA来得轻巧,想与JAVA的MVC对比一番。看了一下ThinkPHP的文档,觉得写得还算不错,但是并不是那种实战型的文档,所以显得比较笼统,很多东西还是得自己摸索。
现就遇到一个问题,即怎么在Windows下连接Oracle进行开发。几乎所有的例子都是基于Mysql的,Oracle的连接本身在Windows平台下就显得比较复杂。这里便长话短说,只记录有用部分。
一、PHP中的Oracle连接
1、把php.ini中的extension=php_oci8.dll开启,前面的注释分号去掉。
2、下载Oracle客户端绿色版本,32位的。到http://www.oracle.com/technetwork/topics/winsoft-085727.html 要注册登录才能下载
我下载的是第一个: http://download.oracle.com/otn/nt/instantclient/112030/instantclient-basic-nt-11.2.0.3.0.zip
解压到E:\app\instantclient_11_2
3、新建一个文件夹,E:\app\TNS,里面新建文本文件tnsnames.ora,上面按照Oracle 的连接规则写上连接串。如填上以下内容:
引用
testme =
(DESCRIPTION=
(ADDRESS_LIST=
(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.199)(PORT=11521))
)
(CONNECT_DATA=(SERVICE_NAME=test)
)
)
3、添加环境变量。推荐用RapidEE这个软件进行环境变量的编辑,非常有用!(微软在一些关键的功能的界面部分总是显得小气得要命,比如这个环境变量编辑,比如WIN中自带的防火墙规则设置,在上面设置个复杂点的东西会令人抓狂!)添加以下环境变量:
TNS_ADMIN=E:\app\TNS
NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK
然后在系统Path变量最前面添加值E:\app\instantclient_11_2;
4、重新启动电脑!(必须的!不然WIN总是不能反应过来)
5、在你的PHP运行环境(推荐用phpnow等)写入一个文件含phpinfo()的,找一找 OCI8 Support 是不是enabled,如果没有这条出现,那PHP连接Oracle肯定会失败。如果出现了,恭喜你,这一步做好了,PHP能够正常连接Oracle的数据库了。
以上的方法是通用的,在32位和64位Windows下都可以使用。
二、ThinkPHP中作连接测试
1、不多说,直接在项目配置文件中写(根据上面的配置而来)
引用
return array(
//数据库配置信息
'DB_TYPE' => 'oracle', // 数据库类型
'DB_HOST' => '192.168.1.199', // 服务器地址
'DB_NAME' => 'testme', // 数据库名
'DB_USER' => 'root', // 用户名
'DB_PWD' => 'root', // 密码
'DB_PORT' => 11521, // 端口
'DB_PREFIX' => 'T_TEST_', // 数据库表前缀
);
特别注意上面的DB_NAME,是本机设置的testme而非服务器上的服务名test,这一点很容易犯迷糊。因为有些框架是使用的服务器上的服务名。但ThinkPHP特别一点,它封装的时候是采用本机侦听名的。
2、在Oracle数据库中建立一个表,前缀是T_TEST_,比如建立一个T_TEST_ADS表。
里面两列ID/NAME(大写)
然后随意的添加几行数据吧。如
3、先要从官网下载扩展包,将其中的Oracle连接支持类DbOracle.class.php放在工程里面。
然后在Thinkphp中的lib中的IndexAction.class.php中写
引用
public function index(){
$Data = M('ads'); // 实例化Data数据模型 注意此处一定是小写的ads,而不能用大写,否则会取不到值的!原因我也不太清楚
$this->data = $Data->select();
$this->display();
}
模板文件:Tpl\Index\index.html
内容:
引用
XYZ
{$vo.ID}--{$vo.NAME}
最外层index.php内容:
引用
define('APP_DEBUG',TRUE); // 开启调试模式
//加载框架入口文件
require './ThinkPHP/ThinkPHP.php';
?>
然后运行这个index.php
你就会看到以下效果啦:
引用
XYZ
0--我
1--他
2--她
3--你
4--晕
至此,大功告成啰。再用其它的功能进行CURD操作吧。