- 论坛徽章:
- 0
|
昨天用AdoDB干活连接Oracle数据库,发现了其中的一个有关字符集的小bug。
为了方便,我们一般都经常喜欢用DSN进行AdoDB的连接,如这样的格式:
$DSN = "oci8://user:passwd@host/sid?charset=ZHS16GBK";
使用oracle的同志应该会很熟悉了,AdoDB对Oracle9i以上的版本提供了指定charset等参数的功能,但在实际使用中,指定的字符集ZHS16GBK并没有如愿发挥作用。经过分析,发现AdoDB4.93a版本中drivers目录中对oracle的adodb-oci8.inc.php文件中有bug,在判断有无charset参数时,把判断后的结果对调了。下面是对该bug的修正:
行212~行230应该为:
if ($mode==1) {
$this->_connectionID = ($this->charSet) ?
OCIPLogon($argUsername,$argPassword, $argDatabasename, $this->charSet)
:
OCIPLogon($argUsername,$argPassword, $argDatabasename)
;
if ($this->_connectionID && $this->autoRollback) OCIrollback($this->_connectionID);
} else if ($mode==2) {
$this->_connectionID = ($this->charSet) ?
OCINLogon($argUsername,$argPassword, $argDatabasename, $this->charSet)
:
OCINLogon($argUsername,$argPassword, $argDatabasename);
} else {
$this->_connectionID = ($this->charSet) ?
OCILogon($argUsername,$argPassword, $argDatabasename,$this->charSet)
:
OCILogon($argUsername,$argPassword, $argDatabasename);
}
本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/3577/showart_223616.html |
|