热门标签 | 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操作吧。
推荐阅读
  • 我的读书清单(持续更新)201705311.《一千零一夜》2006(四五年级)2.《中华上下五千年》2008(初一)3.《鲁滨孙漂流记》2008(初二)4.《钢铁是怎样炼成的》20 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • 在编程实践中,正确管理和释放资源是非常重要的。本文将探讨 Python 中的 'with' 关键字及其背后的上下文管理器机制,以及它们如何帮助我们更安全、高效地管理资源。 ... [详细]
  • Django与Python及其他Web框架的对比
    本文详细介绍了Django与其他Python Web框架(如Flask和Tornado)的区别,并探讨了Django的基本使用方法及与其他语言(如PHP)的比较。 ... [详细]
  • 本文详细介绍了C++中的构造函数,包括其定义、特点以及如何通过构造函数进行对象的初始化。此外,还探讨了转换构造函数的概念及其在不同情境下的应用,以及如何避免不必要的隐式类型转换。 ... [详细]
  • 数据类型--char一、char1.1char占用2个字节char取值范围:【0~65535】char采用unicode编码方式char类型的字面量用单引号括起来char可以存储一 ... [详细]
  • 项目风险管理策略与实践
    本文探讨了项目风险管理的关键环节,包括风险管理规划、风险识别、风险分析(定性和定量)、风险应对策略规划及风险控制。旨在通过系统的方法提升项目成功率,减少不确定因素对项目的影响。 ... [详细]
  • 探索AI智能机器人自动盈利系统的构建
    用户可通过支付198元押金及30元设备维护费租赁AI智能机器人,推荐他人加入可获得相应佣金。随着推荐人数的增加,用户将逐步解锁更高版本,享受更多收益。 ... [详细]
  • 本文探讨了在一个物理隔离的环境中构建数据交换平台所面临的挑战,包括但不限于数据加密、传输监控及确保文件交换的安全性和可靠性。同时,作者结合自身项目经验,分享了项目规划、实施过程中的关键决策及其背后的思考。 ... [详细]
  • importjava.io.*;importjava.util.*;publicclass五子棋游戏{staticintm1;staticintn1;staticfinalintS ... [详细]
  • 解决Visual Studio Code中PHP Intelephense误报问题
    PHP作为一种高度灵活的编程语言,其代码结构可能导致Intelephense插件在某些情况下报告不必要的错误或警告。自1.3.3版本起,Intelephense引入了多个配置选项,允许用户根据具体的工作环境和编程风格调整这些诊断信息的显示。 ... [详细]
  • ABP框架是ASP.NET Boilerplate的简称,它不仅是一个开源且文档丰富的应用程序框架,还提供了一套基于领域驱动设计(DDD)的最佳实践架构模型。本文将详细介绍ABP框架的特点、项目结构及其在Web API优先架构中的应用。 ... [详细]
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社区 版权所有