网上的说法如下:
Java开发Postgresql 数据库兼容应用的问题,与Oracle有一些不同:
Java类型映射数据库类型的不同,Oracle jdbc驱动程序处理Java String类型可正常映射到数据库的Numberic(Integer),而Postgres则会出错。
另外,则是使用hibernate时经常的錯誤: operator不存在:character varying = bytea问题,不要被这个描述误导了,并不是sql语句中character varying = bytea类型的比较,而是当使用hibernate使用参数绑定,而参数的值为null时,hibernate或者Postgresql驱动将这个参数映射为varbinary类型,Postgresql将varbinary认为为bytea类型。
我的错误原因:
数据表的 id Variable characters (50) 为自增的数值型VChar ,Postgresql 在 hibernate 操作下好像是默认转成了其他类型导致没匹配上。
Oracle数据库允许 WHERE ID = ? 然后值传成 String (本来就应该是)
Postgresql 数据库中只能写成:
WHERE id = '"+MapUtils.getString(paramMap, "id")+"'");
另外删除数据时 Postgresql 中需要加 from
delete from 表 where 条件 (Oracle 中 只需要 delete 表 where 条件)