Windows 2003 下 PHP5.2.5 + Apache2.2.8 + Oracle10g/11g 的配置

    PHP 和 Apache 已经配置完毕,成功集成在一起工作(相关文章和经验介绍参见本人博客:http://blog.why100000.com)。但为了使 PHP 能够操作 Oracle 数据库,仅仅打开 php.ini 文件的 php_oci8.dll 扩展是不够的,因为 PHP 的扩展也是调用 Oracle 的底层 API 来工作的(包含在 oci.dll 文件中),所以还必须安装 Oracle 的 client 函数库。

    到网址 http://www.oracle.com/technology/software/tech/oci/instantclient/htdocs/winsoft.html 下载 instantclient-basic-win32。注意不是 instantclient-basiclite-win32,因为 basiclite 只支持英文和西欧字符集。instantclient-basic-win32 目前版本是 Version 11.1.0.7.0,即下载文件 instantclient-basic-win32-11.1.0.7.0.zip 即可。

    解压该软件包,比如放到 D:/instantclient_11_1 文件夹下,将这个路径添加到系统变量 PATH 中去,最好添加在路径的开头。再在系统变量里面加一个 TNS_ADMIN 变量,值也设为C:/instantclient_11_1。最后把 php.ini 里面的 extension=php_oci8.dll 打开,为了支持 PDO,也可以打开 extension=php_pdo_oci.dll 和 extension=php_pdo_oci8.dll,去掉前面的注释分号就行了。

    但这时打开存取 Oracle 数据库的 PHP 页面,又会出现“ORA-12705”错误,即:

    ORA-12705: Cannot access NLS data files or invalid environment specified in ……

    解決办法:按以下路径打开注册表:HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE,找到 NLS_LANG 键值 ,这个键值现在是 NA,因此將 NLS_LANG 的值改为 SIMPLIFIED CHINESE_CHINA.ZHS16GBK,和 Oracle 数据库服务器上的一致。

    再加三个环境变量的值

    TNS_ADMIN 等于 D:/instantclient_11_1
    NLS_LANG 等于 SIMPLIFIED CHINESE_CHINA.ZHS16GBK
    LD_LIBRARY_PATH 等于 D:/instantclient_11_1

    完成后,注册表中会自动记录在以下路径:

    [HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Control/Session Manager/Environment]
    "LD_LIBRARY_PATH"="D:/instantclient_11_1"
    "NLS_LANG"="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"
    "TNS_ADMIN"="D:/instantclient_11_1"

    如果使用了 tnsnames.ora 文件定义 Oracle 网络服务名称(tnsnames.ora文件在数据库服务器的 [ORACLE_HOME]/network/admin文件夹下),则将 tnsnames.ora 复制到 D:/instantclient_11_1,并添加用户环境变量 TNS_ADMIN,设置为你的解压目录如 D:/instantclient_11_1。(也可以在用户环境变量 LOCAL 中定义默认的服务名称。)

    客户管理包里还有一些很有用的程序,如启动 sqlplus 为 sqlplus system/manager@localdb。Oracle ODBC 的安装可以运行 odbc_install 或者 odbc_install ZHS。

    这时用 phpinfo() 函数应该看到浏览器输出页面应包含一个显示“OCI8 Support enabled”的信息。这样就配置好了,写一段代码测试吧。

    作者:张庆(网眼) 2009-10-21
    来自“网眼视界”:http://blog.why100000.com
    “十万个为什么”电脑学习网:http://www.why100000.com

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值