我是靠谱客的博主 无辜万宝路,最近开发中收集的这篇文章主要介绍think-oracle扩展,php 扩展之oci8在ThinkPHP上的应用,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

最近突然想到了oci_8的拓展,PHP的一个拓展,有很多函数,翻了翻手册,看了看ThinkPHP的DB以及DBOracle的驱动文件

这才想明白其中的oci_connect和oci_pconnect以及oci_new_connect的来源

代码如下/**

* 连接数据库方法

* @access public

*/

public function connect($config='',$linkNum=0) {

if ( !isset($this->linkID[$linkNum]) ) {

if(empty($config))  $config = $this->config;

$pconnect   = !empty($config['params']['persist'])? $config['params']['persist']:$this->pconnect;

$conn = $pconnect ? 'oci_pconnect':'oci_new_connect';

$this->linkID[$linkNum] = $conn($config['username'], $config['password'],$config['database'],C('DB_CHARSET'));//modify by wyfeng at 2008.12.19

if (!$this->linkID[$linkNum]){

$this->error(false);

}

//这里的有两个函数oci_pconnect和oci_new_connect是oci8拓展里的,oci_connect也是

//例如:$conn = oci_connect('system','oracle','192.168.109.132:49161/xe');

//192.168.109.132:49161/xe--->这种字符串连接是简单连接,需要在oracle10g以上才能使用

//完整 Oracle Net 连接字符串提供了足够的连接灵活性。

//$db = MYDB2 = (DESCRIPTION =

//(ADDRESS = (PROTOCOL = TCP)

//(HOST = mymachine.mydomain)(PORT = 1521))

//(CONNECT_DATA=

//(SERVER = DEDICATED)

//(SERVICE_NAME = MYDB.AU.ORACLE.COM)))';

//oci8 扩展始终需要查找 Oracle 库和消息文件。找不到正确的文件将导致 PHP 返回 Oracle“ORA-12705:Cannot access NLS data files or invalid environment specified”。

// 标记连接成功

$this->connected = true;

//注销数据库安全信息

if(1 != C('DB_DEPLOY_TYPE')) unset($this->config);

}

return $this->linkID[$linkNum];

}

不是造轮子,而是去理解别人是如何来组织原生的写法,我觉得ThinkPHP的一些处理还是不错的。

最近开始觉得oci_8的函数可以看着手册来试一下。有新的感触会写在这里

最后

以上就是无辜万宝路为你收集整理的think-oracle扩展,php 扩展之oci8在ThinkPHP上的应用的全部内容,希望文章能够帮你解决think-oracle扩展,php 扩展之oci8在ThinkPHP上的应用所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(41)

评论列表共有 0 条评论

立即
投稿
返回
顶部