Hibernate left join(左连接…

Hibernate left join一直是困扰我的一个问题,因为对hibernate的关联映射不怎么了解,写的Hql也全部是从sql翻译过来,虽然也是大同小异,因此左连接一直不会用。

其实很简单:

1、先把关联映射配好

User.hbm.xml

<hibernate-mapping package="com.xieqing.crm.user">

<class name="User" table="tbl_user">

   <id name="id" column="id">

      <generator class="native"/>

   </id>

   <property name="truename" not-null="true" column="truename" length="32"/>

   <property name="sex" column="sex" length="1"/>

   <property name="phone" column="phone"/>

   <property name="roomId" column="room_id"  not-null="false"/>

   <many-to-one name="room" class="com.xieqing.crm.room.Room" column="room_id" 

         insert="false" update="false"/>

</class>

</hibernate-mapping>


 

Room.hbm.xml

<hibernate-mapping package="com.xieqing.crm.room">

<class name="Room" table="tbl_room">

   <id name="id" column="room_id">

      <generator class="native"></generator>

   </id>

   <property name="roomName" not-null="true" column="room_name" length="32"/>

   <set name="users">

      <key column="room_id"></key>

      <one-to-many class="com.xieqing.crm.user.User" not-found="ignore"/>

   </set>

</class>

</hibernate-mapping>

   

 

User.java

public class User{

    private Integer id;

    private String truename;

    private String phone;

    private int sex;

    private Integer roomId;

    private Room room;

// 省略Getter setter方法

}


 

Room.java

public class Room {

    private Integer id;

    private String roomName;

    private Set<User> users;

// 省略Getter setter方法

 

}

 

tbl_user 

[转载]Hibernate <wbr>left <wbr>join(左连接)


 

tbl_room 

[转载]Hibernate <wbr>left <wbr>join(左连接)


 

// 注意:这里连接的就是User.java里的room属性了改了这里就OK啦。如果后面要加条件就             

         with SQL是用的on

String hql "select from User left join u.room";

List<User> userList this.getHibernateTemplate().find(hql).list();

System.out.println("size----"+userList.size());

for(User userList) {

    System.out.println(u.getId() --- " u.getTruename());

}

 

执行该查询将把tbl_user表中的4个人都查出来。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值