热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

最近对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(大写)
然后随意的添加几行数据吧。如
引用
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
内容:
引用







XYZ


    
    {$vo.ID}--{$vo.NAME}

    




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


然后运行这个index.php

你就会看到以下效果啦:

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


至此,大功告成啰。再用其它的功能进行CURD操作吧。
推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • MySQL中枚举类型的所有可能值获取方法
    本文介绍了一种在MySQL数据库中查询枚举(ENUM)类型字段所有可能取值的方法,帮助开发者更好地理解和利用这一数据类型。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
author-avatar
十饮魂
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有