hibernate里联合主键composite-id映射,查询单个主键的问题

Posted 坏~牧羊人

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hibernate里联合主键composite-id映射,查询单个主键的问题相关的知识,希望对你有一定的参考价值。

今天项目中遇到这个问题,搞了大半天,现在记录下来
hibernate里联合主键配置(多个字段一起作为主键)

<class name="com.cskj.hibernate.map.BbWjjc" table="bb_wjjc" schema="dbo" catalog="wjgl">
        <composite-id name="id" class="com.cskj.hibernate.map.BbWjjcId">
            <key-property name="wjtmid" type="java.lang.Long">
                <column name="wjtmid" />
            </key-property>
            <key-property name="wjxxid" type="java.lang.Long">
                <column name="wjxxid" />
            </key-property>
            <key-property name="wjzxxid" type="java.lang.Long">
                <column name="wjzxxid" />
            </key-property>
            <key-property name="wjztmid" type="java.lang.Long">
                <column name="wjztmid" />
            </key-property>
            <key-property name="wjid" type="java.lang.Long">
                <column name="wjid" />
            </key-property>
        </composite-id>

 

主键的生成文件

public class BbWjjcId implements java.io.Serializable {

 private Long wjtmid;
 private Long wjxxid;
 private Long wjzxxid;
 private Long wjztmid;
 private Long wjid;
。。。。。。

}

 

查询单个主键时用HQL语句

from BbWjjc bw where bw.BbWjjcId.wjid=? 
结果报错:
 could not resolve property: BbWjjcId of: com.cskj.hibernate.map.BbWjjc [from com.cskj.hibernate.map.BbWjjc bw where bw.BbWjjcId.wjid=‘5‘]

上网查了一下,说是hql语句的问题.
测试了大半天结果调试正常了,原来是bw.BbWjjcId.wjid=?中的BbWjjcId要写映射xml中的name(即:id),不能写PK类名字.
正确的HQL: from BbWjjc bw where bw.id.wjid=? 艰难搞定!!!!

以上是关于hibernate里联合主键composite-id映射,查询单个主键的问题的主要内容,如果未能解决你的问题,请参考以下文章

Hibernate注解映射联合主键的三种主要方式(转载)

hibernate联合主键 注解方式

hibernate 联合主键

hibernate ——联合主键

hibernate MTM 联合主键

Hibernate xml配置方法之联合主键