热门标签 | 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操作吧。
推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文讲述了作者通过点火测试男友的性格和承受能力,以考验婚姻问题。作者故意不安慰男友并再次点火,观察他的反应。这个行为是善意的玩人,旨在了解男友的性格和避免婚姻问题。 ... [详细]
  • 本文介绍了使用PHP实现断点续传乱序合并文件的方法和源码。由于网络原因,文件需要分割成多个部分发送,因此无法按顺序接收。文章中提供了merge2.php的源码,通过使用shuffle函数打乱文件读取顺序,实现了乱序合并文件的功能。同时,还介绍了filesize、glob、unlink、fopen等相关函数的使用。阅读本文可以了解如何使用PHP实现断点续传乱序合并文件的具体步骤。 ... [详细]
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社区 版权所有