首页 > 后端开发 > php教程 > 请教PDO为什么连接不下oracle

请教PDO为什么连接不下oracle

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-13 13:00:41
原创
2440 人浏览过

请问PDO为什么连接不上oracle
数据库环境Oracle 11g 64位  window server 2003
PHP环境:32位php,运行在windows XP上。
01.
02.try {

03.    

04.    $dbh = new PDO('oci:dbname=//172.30.1.39:1521/orcl;charset=utf8', 'scott','neusoft');

05.

06.    foreach($dbh->query('SELECT * from test') as $row) {

07.        print_r($row);

08.        print("


");

09.    }

10.    $dbh = null;

11.} catch (PDOException $e) {

12.    print "Error!: " . $e->getMessage() . "
";

13.    die();

14.}

15.?>
错误:
01.Error!: SQLSTATE[HY000]: OCIEnvNlsCreate: Check the character set is valid and that PHP has access to Oracle libraries and NLS data (ext\pdo_oci\oci_driver.c:558)

如果修改成
01.
02.try {

03.    

04.    $dbh = new PDO('oci:dbname=//172.30.1.39:1521/orcl', 'scott','neusoft');

05.

06.    foreach($dbh->query('SELECT * from test') as $row) {

07.        print_r($row);

08.        print("
");

09.    }

10.    $dbh = null;

11.} catch (PDOException $e) {

12.    print "Error!: " . $e->getMessage() . "
";

13.    die();

14.}

15.?>
则报错:
01.Error!: SQLSTATE[]: pdo_oci_handle_factory:  (ext\pdo_oci\oci_driver.c:579)

------解决方案--------------------
检查tnsnames.ora,listener.ora中,sqlnet.ora中,日志文件看看

------解决方案--------------------
前者是字符集名称错了
关键在于后者,你的 oci 版本是否低于 oracle 版本?
相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板