我有两张表a(id,bno) b(id,no),在数据库中定义了bno和no关联,检索a表时用用Hibernate.initialize()方法强制初始化POJO-a的成员bno,结果抛Unhandled Exception thrown: class org.hibernate.ObjectNotFoundException
我的表a中有一条记录,其bno值为11,而b表中也有一条记录,其no值为11
经测试发现原因是:在强制初始化时,hibernate竟然拿a表中的bno同b表中的id字段关联检索,结果当然是找不着对应的记录了,我尝试着把b表中的那条记录的id改成11,反倒是关联成功了。
通过修改主表和子表的配置文件,已经把问题解决了
可是我想知道,除了修改配置文件的方法,在程序中直接处理需怎么写代码。
[b]问题补充:[/b]
感谢 sunleije 的回答
可是通过修改配置文件来解决的方法我已经知道,我想知道我是:在不借助于修改配置文件的情况下,如何在程序中设置这种非主键关联的细节。
[b]问题补充:[/b]
SQL很好写,不知道用HQL怎么写,望赐教,这个答完就给分
1、群组映射:
2、域映射:
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xirenzhang/archive/2009/08/28/4492481.aspx
程序中就用 createSQLQuery吧 select * from table1 a,table2 b where a.id=b.id ......
HQL一样 form table1, table2 where...
可以使用 inner join,left outer join, right out join, full join