APACHE PHP5 ORACLE设置

在windows 下配置PHP使用ORACLE数据库要点

 

在window下,经常用apache + PHP 来做应用平台,但是如果使用oracle做后台数据库,但又没有安装有oracle客户端,下面的配置可以参考

 

1、在没有安装oracle的机器上,PHP无法加载php_oci8.dll模块,原因是php_oci8.dll依赖的相关组件没有找到。

     你正确设置了extension_dir = "C:/Apache/php/ext/"

     并且打开了 extension=php_oci8.dll

     但是查看apache的日志(在logs/error.log中),发现类似的错误

    PHP Warning:  PHP Startup: Unable to load dynamic library 'C://Apache//php//ext//php_oci8.dll' - /xd5/xd2/xb2/xbb/xb5/xbd/xd6/xb8/xb6/xa8/xb5/xc4/xc4/xa3/xbf/xe9/xa1/xa3/r/n in Unknown on line 0

 

那就会是上面描述的情况,使用oracle8扩展需要 Oracle 客户端库。Windows 用户需要至少版本号为 10 的库才能使用 php_oci8.dll

到这个地址下载需要的版本 http://www.oracle.com/technology/tech/oci/instantclient/index.html

 

   不过,下载需要一个注册才可以,如果你已经注册过,那么登录就可以了,你下载后是一个zip包,只需把那个包解压到一个目录中

比如  c:/oracle_client/ 那么,把这个地址加到 path中即可

 

   但是这样还不够,还需要设置 TNS_ADMIN 这个变量,把这个变量的值设置为 tnsnames.ora文件所在的目录即可。

 

   下面是tnsnames.ora的例子

 

   ORCL =

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.102)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = orcl)

    )

    )

 

  下面是一个测试例子

 

 <?php

 

$connection = oci_connect("hr", "pass","orcl","UTF8");

$query = "SELECT * from user_tables";

$statement = oci_parse ($connection, $query);

oci_execute ($statement);

 

    // 打印执行结果

    print '<table border="1">';

    while($row = oci_fetch_array($statement, OCI_NUM)) {

        print '<tr>';

        foreach( $row as $item) {

          print '<td>'.$item.'</td>';

        }

        print '</tr>';

    }

    print '</table>';

    oci_close($connection);

?>

 

$connection = oci_connect("hr", "pass","orcl","UTF8");

第一个参数: hr 是登录数据库的用户名

                 pass是密码

                 orcl是tnsnames.ora中设置的项

                utf8是数据库的字符集

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值