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映射,查询单个主键的问题的主要内容,如果未能解决你的问题,请参考以下文章