Criteria使用Postgres查询

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (25)

使用: - Postgres:PostgreSQL 10.0 Hibernate:4.0.1

我在Postgres中创建了以下示例表

CREATE TABLE Automobile
(id                          SERIAL               
,name                        VARCHAR(20)        
,year                        INTEGER        
);

我创建了一个域汽车类。

我有以下hibernate条件查询来返回特定年份的所有名称。

    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

有什么可能的原因和解决方案可以回复我的比赛列表吗?

提问于
用户回答回答于

在你有Hibernate映射

<property name="year" type="java.lang.String" >

您没有向您展示Java代码。我想年份也是String。

但在数据库一年是一个整数。

解决方案:按如下方式更改映射:还要更改Java类并将year定义为Integer。

所属标签

可能回答问题的人

  • 优惠活动秘书

    0 粉丝2 提问8 回答
  • 天使的炫翼

    17 粉丝531 提问7 回答
  • 最爱开车啦

    8 粉丝503 提问6 回答
  • uncle_light

    5 粉丝518 提问5 回答

扫码关注云+社区

领取腾讯云代金券