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

10/24/2009来源:PHP教程人气:8125

    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