>  기사  >  php教程  >  pgsql下若干问题的解决办法

pgsql下若干问题的解决办法

WBOY
WBOY원래의
2016-06-07 11:44:192367검색

TP使用pgsql时会出现某些问题,现给出解决办法,以供参考
1.add()方法无法获取新增的主键值,修改pgsql驱动:Db.Pgsql.class.php的134行:list($last_insert_id)   =   pg_fetch_array($result,null,PGSQL_ASSOC);经过测试,这里并未将新增ID的值赋给$last_insert_id,所以改成$last_insert            =   pg_fetch_array($result,null,PGSQL_ASSOC);return那里改成:return  $last_insert['insert_id'];2.由于sql中存在pgsql的关键字而引起的错误:
①:RBAC.class.php
由于user是pgsql的关键字,而在这个RBAC.class.php中的sql中含有user,从而出现sql错误,故将此文件中4个sql中的'user'改成'users',然后将214行、227行、240行、258行的:                    $table['user']." as user,".改成                    $table['user']." as users,". ②:视图模型下sql语句错误:SELECT COUNT(*) AS tp_count FROM tp_user User还是因为user是pgsql的关键字;
更正方法:将user表改名为users或其它
总之,sql中出现了pgsql的关键字时就要注意了,
数据表名、字段名、字段别名等不能使用pgsql的关键字,如:user、group等

另外,pgsql下NOT NULL字段不允许插入null值,而在mysql下却可以,一定要注意这一点,一不小心就会导致sql语法错误。
其它bug正在查找

AD:真正免费,域名+虚机+企业邮箱=0元

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.