码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2015-05-23 22:43:18      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:

今天项目中遇到这个问题,搞了大半天,我郁闷...
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映射,查询单个主键的问题(转)

标签:

原文地址:http://www.cnblogs.com/Mangues/p/4524912.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!