ThinkPHP在Windows下连接Oracle数据库开发

快乐无极 , 2012/12/28 23:24 , 开发文档 , 评论(0) , 阅读(29758) , Via 本站原创 | |
最近对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(大写)
然后随意的添加几行数据吧。如
引用
0 我
1 他
2 她
3 你
4 晕


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
内容:
引用
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>数据库测试连接</title>
</head>
<body>
XYZ
<br/>
     <volist name="data" id="vo">
    {$vo.ID}--{$vo.NAME}<br/> <!--注意这里的属性值都应该是大写的,和上面的数据库对应。一般Oracle中的属性值都是大写的哦。-->
    </volist>
</body>
</html>


最外层index.php内容:
引用
<?php
define('APP_DEBUG',TRUE); // 开启调试模式
//加载框架入口文件
require './ThinkPHP/ThinkPHP.php';
?>


然后运行这个index.php

你就会看到以下效果啦:

引用
XYZ
0--我
1--他
2--她
3--你
4--晕


至此,大功告成啰。再用其它的功能进行CURD操作吧。
发表评论

昵称

网址

电邮

打开HTML 打开UBB 打开表情 隐藏 记住我 [登入] [注册]