使用:- Postgres : PostgreSQL 10.0 Hibernate : 4.0.1
我在Postgres中创建了以下示例表
CREATE TABLE Automobile
(id SERIAL
,name VARCHAR(20)
,year INTEGER
);
我已经创建了一个域Automobile类。
我使用以下hibernate criteria查询来返回特定年份的所有名称。
final Criteria criteria = session.createCriteria (Automobile.class);
criteria.add (Restrictions.eq ("year", 1 ));
List<Automobile> list = criteria.list();
但是,list()正在生成以下异常。
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
因此,我更改了查询,以传递“年份”的字符串值:
criteria.add (Restrictions.eq ("year", new String("1")));
List<Automobile> list = criteria.list();
但是,list()正在生成一个不同的异常。
org.hibernate.exception.SQLGrammarException: ERROR: operator does not exist: integer = character varying
Hint: No operator matches the given name and argument type(s). You might need to add explicit type casts.
Position: 1145
有什么想法,也许是原因和解决方案,将返回我的比赛列表,请?
谢谢你皮特。
发布于 2018-06-09 07:28:00
在Hibernate映射中,您有
<property name="year" type="java.lang.String" >
您没有向您展示Java代码。我想year在那里也是字符串。
但是在数据库中,年份是一个整数。
解决方案:如下所示更改您的映射:同时更改您的Java类,并将年份定义为整数。
https://stackoverflow.com/questions/50769083
复制相似问题