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