`
zengshaotao
  • 浏览: 763452 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Hibernate 多对一 left join

 
阅读更多

hibernate的hql是一种中立的数据库查询语言,会随着本地配置的方言选项,进行sql的翻译。

 

User.hbm.xml

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

<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.crm">

<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 u from User u left join u.room";

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

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

for(User u : userList) {

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

}

 

 

分享到:
评论

相关推荐

    Hibernate表关系总结(一对一,多对一,多对多)

    Hibernate表关系总结(一对一,多对一,多对多,单向,双向),有具体实例代码

    Hibernate-HQL语句多对多写法

    2. 在多对多关系的情况下,需要使用 left join 或 inner join 来连接实体类。 3. 使用 where 子句可以过滤出特定的数据。 4. 在 HQL 语句中,使用 join 子句可以连接多个实体类。 5. 在多对多关系的情况下,需要使用...

    Hibernate问题解决

    Hibernate问题 &lt;br&gt;1、表连接的查询,当表中有外键连接其它表时,如何能一次查出所有的内容?... 7、left join与right join具体应如何在Hibernate中配置? 8、统计如何实现?如何配置?java类如何来写?

    hibernate总结

    Hibernate映射多对多(两个一对多实现多对多) 表:材料表和产品表多对多,在数据库中有中间表即产品材料表用来存放两个表之间的关系 Java类:材料PO,产品PO,中间PO,中间PO的复合主键类(由于是两个一对多形成的多对...

    hibernate性能优化.doc

    在 Hibernate 中,经常存在 1 对多关联关系,例如一个新闻对应多个评论。在这种情况下,如果我们查询新闻对象时,会发出 1+n 条查询语句,这将严重影响应用程序的性能。 解决方法是使用 HQL、Criteria 或 Hibernate...

    Hibernate查询语言(HQL) 语法参考

    我们也可以使用 left outer join、right outer join、full join 等连接类型。 fetch 连接 fetch 连接允许我们使用一个选择语句就将相关联的对象或一组值的集合随着他们的父对象的初始化而被初始化,例如: ``` ...

    hibernatemanytomany:使用两个实体的投影Hibernate多对多示例

    问题:如何跨多对多关系的两个实体投影列示例:员工(id、名字、姓氏)会议(id、主题、会议日期) 假设我们有员工数据 1 , A, AA 2 , B, BB 会议 1,AB 会议,X 2,另一个会议,X 3,仅 B Employee_Meeting AB A 和...

    HQL查询语言基础知识

    HQL 中的 JOIN 语句用于关联多个表,包括 INNER JOIN、LEFT JOIN、RIGHT JOIN 和 FULL JOIN。 * INNER JOIN:select employee.ID as id1,employee.Name as name1,department.ID as id2,department.Name as name2 ...

    hsql查询语法

    HSQL支持的连接类型包括inner join、left outer join、right outer join和full join。例如: from Formula form full join form.parameter param 4. FETCH连接 HSQL还支持FETCH连接,用于将关联的对象或一组值的...

    SSH框架部分常见面试题.pdf

    实体之间的关联关系有三种:一对一、一对多、多对多。 DOM 和 SAX DOM 是文档对象模型,用于将 XML 文档转换到 Java 对象中。SAX 是简单 API 用于 XML,用于将 XML 文档转换到 Java 对象中。 Hibernate 对象的三...

    SSH+EASY-UI的账务管理系统

    用MAVEN,SPRING,...AS `goodsquality`,avg(`b`.`price`) AS `price`,`a`.`id` AS `id`,`a`.`name` AS `name` from (`goods` `a` left join `goodsprice` `b` on((`a`.`id` = `b`.`goods_id`))) group by `a`.`id`

    java高级工程师面试题

    Java高级工程师面试题 本资源摘要信息涵盖了Java高级工程师面试题,涵盖了智力部分和专业部分。智力部分包括了五道题目,涉及到逻辑思维、问题解决和计量题目。...可以使用LEFT JOIN和MINUS关键字来实现SQL查询。

Global site tag (gtag.js) - Google Analytics