pgsql下若干问题的解决办法
程序员文章站
2022-03-04 09:59:32
...
TP使用pgsql时会出现某些问题,现给出解决办法,以供参考
1.add()方法无法获取新增的主键值,修改pgsql驱动:Db.Pgsql.class.php的134行:
①:RBAC.class.php
由于user是pgsql的关键字,而在这个RBAC.class.php中的sql中含有user,从而出现sql错误,故将此文件中4个sql中的'user'改成'users',然后将214行、227行、240行、258行的:
更正方法:将user表改名为users或其它
总之,sql中出现了pgsql的关键字时就要注意了,
数据表名、字段名、字段别名等不能使用pgsql的关键字,如:user、group等
另外,pgsql下NOT NULL字段不允许插入null值,而在mysql下却可以,一定要注意这一点,一不小心就会导致sql语法错误。
其它bug正在查找
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元
推荐阅读
-
IE8下载文件时无法调用迅雷怎么办?IE8浏览器无法用迅雷下载问题的解决办法介绍
-
Linux系统下ssh登陆很慢的解决办法
-
CentOS 6下root密码忘记的解决办法
-
linux下oracle报错,提示ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务的解决办法
-
windows10下使用IE浏览器出现报错的解决办法
-
Android下修改SeekBar样式的解决办法
-
linux下xhost命令报错:unable to open display的解决办法
-
HTTP 499 状态码 nginx下 499错误的解决办法
-
php curl获取网页内容(IPV6下超时)的解决办法
-
Android Fragment中使用SurfaceView切换时闪一下黑屏的解决办法