yih111 2008-12-01 00:41
浏览 167
已采纳

hibernate多表查询

如下三张表:


create table admin(
id int identity(1,1) primary key,
adminName varchar(12) not null,
adminPwd varchar(18) not null,
nickName varchar(18) not null
)


create table sort(
id int identity(1,1) primary key,
sortName varchar(30) not null
)


create table article(
id int identity(1,1) primary key,
title varchar(100) not null,
content varchar(7500) not null,
writeDate varchar(30) not null,
visitCount int not null default(0),
sortId int references sort(id),
adminId int references admin(id)
)


下面为*.hbm.xml的一对多,多对一的代码
Admin.hbm.xml
...
<set name="articles">
<key>
<column name="adminId">
</key>
<one-to-many class="com.hail.blog.model.Article">
</set>
...

Sort.hbm.xml
...
<set name="articles">
<key>
<column name="sortId">
</key>
<one-to-many class="com.hail.blog.model.Article">
</set>
...

Article.hbm.xml
...
<many-to-one name="admin" class="com.hail.blog.model.Admin" fetch="select">
<column name="adminId">
</many-to-one>
<many-to-one name="sort" class="com.hail.blog.model.Sort" fetch="select">
<column name="sortId">
</many-to-one>
...

我的查询语句为:
Query query = session.createQuery("from Admin a,Article aa,Sort s where aa.admin=a.id and aa.sort=s.id order by aa.writeDate desc");
但是页面不会显示出值来,请各位帮帮忙看看该怎么写

 

不好意思,本人目前没有积分可送

  • 写回答

2条回答 默认 最新

  • earthsky 2008-12-01 08:52
    关注

    Query query = session.createQuery("from Admin a,Article aa,Sort s where aa.admin=a.id and aa.sort=s.id order by aa.writeDate desc"); 中的aa.admin=a.id and aa.sort=s.id 语句改成aa.admin.id=a.id and aa.sort.id=s.id试试了,
    我想是你的aa.admin是Admin对象,怎样等于id字段那,aa.sort同样

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥50 树莓派安卓APK系统签名
  • ¥15 maple软件,用solve求反函数出现rootof,怎么办?
  • ¥65 汇编语言除法溢出问题
  • ¥15 Visual Studio问题
  • ¥20 求一个html代码,有偿
  • ¥100 关于使用MATLAB中copularnd函数的问题
  • ¥20 在虚拟机的pycharm上
  • ¥15 jupyterthemes 设置完毕后没有效果
  • ¥15 matlab图像高斯低通滤波
  • ¥15 针对曲面部件的制孔路径规划,大家有什么思路吗