Allin's blog

先做正确的事,然后才是正确的做事

leeshaoqunID:leeshaoqun
135781次访问,排名550好友0人,关注者2
leeshaoqun的文章
原创 90 篇
翻译 1 篇
转载 129 篇
评论 35 篇
allin的公告
  • leeshaoqun的博客
  • 电子科技大学中山学院
  • 计算机工程系
老照片
最近评论
mldstk:wow gold,
mldstk:wow gold,
alex.xu:漂亮 ,说实话 比官方文档写的好
lkuzhi:是啊,能不能找个能用的过来啊
泽雄:已经不能用了
文章分类
收藏
    相册
    ♡韩国可爱的小童星 ♡
    korea
    韩佳人
    金泰熙
    宋惠乔
    宋慧乔车太贤《我和我的女友》
    微笑美女——韩孝珠
    Hibernate
    Hibernate中文网
    Hibernate官方网站
    php
    Haohappy的专栏--PHP5研究中心
    Spring
    Raible's Wiki -- AppFuse
    Spring 开发参考手册
    SpringFramework中文论坛
    SpringFramework官方站点
    个人博客
    greengnn's space
    开源
    java开源大全(RSS)
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 Eclipse快速上手Hibernate--7. 关联映射(一对多) (2)收藏

    新一篇: Eclipse快速上手Hibernate--7. 关联映射(一对多) (3) | 旧一篇: Eclipse快速上手Hibernate--7. 关联映射(一对多) (3)

        上篇文章《Eclipse快速上手Hibernate--7. 关联映射(一对多) (1)》已经说了一对多的单向关联,这次还是用Room和User类来说明多对一的单向关联,只不过这次关联关系是由User对象维持的。
     
      由于有了上篇文章的基础,只要做些修改就可以了。
     
     
    · 修改Room类,仅仅是删除了关联User类的代码。

    Room.java

    package javamxj.hibernate.association.one2many;
    
    /**
     * @hibernate.class table = "T_Room"
     */
    public class Room {
    
    	private Long id;
    	private String address;
    	
    	/**
    	 * @hibernate.id
    	 *	column="ID"
    	 *	generator-class="hilo" 
    	 *	unsaved-value="null"
    	 */
    	public Long getId() {
    		return id;
    	}
    	public void setId(Long id) {
    		this.id = id;
    	}
    	
    	/**
    	 * @hibernate.property length = "24"
    	 */
    	public String getAddress() {
    		return address;
    	}	
    	public void setAddress(String address) {
    		this.address = address;
    	}
    	
    }
     
     
     
    ·  同样修改User类,也是仅仅添加了关联Room类的代码。

    User.java

    package javamxj.hibernate.association.one2many;
    
    /**
     * @hibernate.class table = "T_User"
     */
    public class User {
    
    	private Long id;
    	private String name;
    	private Room room;
    	
    	/**
    	 * @hibernate.id
    	 *	column="ID"
    	 *	generator-class="hilo" 
    	 *	unsaved-value="null"
    	 */
    	public Long getId() {
    		return id;
    	}
    	public void setId(Long id) {
    		this.id = id;
    	}
    
    	/**
    	 * @hibernate.property length = "24"
    	 */
    	public String getName() {
    		return name;
    	}
    	public void setName(String name) {
    		this.name = name;
    	}
    	
    	/**
    	 * @hibernate.many-to-one
    	 * 	cascade="save-update" 
    	 *  column="Room_ID"
    	 */
    	public Room getRoom() {
    		return room;
    	}
    	public void setRoom(Room room) {
    		this.room = room;
    	}
    	
    }
    ·  在最后几行中指明了引用Room类的方式,其中@hibernate.many-to-one 表明在T_User表定义了外键Room_ID。通过这个外键来反映多对一关系。
     
     
     
     
     
    ·  看看Room类的映射文件中的有关多对一关联部分:

          <many-to-one
                name="room"
                class="javamxj.hibernate.association.one2many.Room"
                cascade="save-update"
                outer-join="auto"
                update="true"
                insert="true"
                access="property"
                column="Room_ID"
            />

    · 这次级联关系是 cascade="save-update", 当删除多的一方中的一个对象时,其所关联的一的一方并不能同时被删除,因为它有可能还关联着多的一方中的其它对象,所以这次不用 cascade="all" 了。

     

         
    · 修改Demo.java文件,User通过级联来更新Room。

    Demo.java

    /*
     * Hibernate - 关联(Association)映射(一对多)
     * 创建日期 2005-4-27
     * @author javamxj(分享java快乐)
     * @link  Blog: htpp://blog.csdn.net/javamxj/ 
     *              htpp://javamxj.mblogger.cn 
     */
    package javamxj.hibernate.association.one2many;
    
    import net.sf.hibernate.*;
    import net.sf.hibernate.cfg.*;
    
    public class Demo {
    	public static void main(String[] args) throws HibernateException {
    				
    		Room room1 = new Room();
    		room1.setAddress("科研007");
    
    		Room room2 = new Room();
    		room2.setAddress("销售001");
    
    		User user1 = new User();
    		user1.setName("张三");
    		user1.setRoom(room1);
    
    		User user2 = new User();
    		user2.setName("李四");
    		user2.setRoom(room1);
    
    		User user3 = new User();
    		user3.setName("王二");
    		user3.setRoom(room2);
    
    		SessionFactory sf= new Configuration().configure().buildSessionFactory();
    		Session session = sf.openSession();
    		Transaction tx = session.beginTransaction();
    		
    		session.save(user1);
    		session.save(user2);
    		session.save(user3);
    		
    		tx.commit();
    		session.close();
    		sf.close();
    
    	}
    
    }
    
     
     
     
     
    ·  然后同上面文章一样,生成映射文件,生成表,执行Demo,最后数据表中生成如下数据: 
     
     
     
     
    ·  同时,控制台输出如下:
      可以看到,多对一关联相比一对多关联,只用了5条语句就完成了相同的操作结果。由于关联关系由User对象维持的,每个User都对应至一个Room。它首先存储的是Room对象,在存储User对象时,因为User已经知道Room的存在,所以可以通过关联字段Room_ID将User对象对Room对象的关系一并存储在T_User表中了。
      
      这两篇文章谈论的都是单向关联,如果Room类和User类存在双向关联,又该如何呢?下篇文章见。

    发表于 @ 2006年02月18日 19:41:00|评论(loading...)|编辑

    新一篇: Eclipse快速上手Hibernate--7. 关联映射(一对多) (3) | 旧一篇: Eclipse快速上手Hibernate--7. 关联映射(一对多) (3)

    评论

    #shaulce 发表于2006-04-28 10:12:00  IP: 211.69.199.*
    写得不错!
    #Vassilis 发表于2007-08-31 20:33:13  IP: 66.232.125.*
    Interesting...
    #Demetri 发表于2007-08-31 22:25:41  IP: 61.241.146.*
    Nice
    #Yiannis 发表于2007-09-01 01:30:52  IP: 74.52.25.*
    interesting
    #Aiakos 发表于2007-09-01 09:36:00  IP: 66.232.123.*
    Interesting...
    #Vasilis 发表于2007-09-01 11:06:21  IP: 66.232.114.*
    Nice!
    #Ioannes 发表于2007-09-02 01:28:00  IP: 66.232.125.*
    interesting
    #Aleda 发表于2007-09-02 02:58:47  IP: 66.232.114.*
    Sorry :(
    #Tzannas 发表于2007-09-02 06:25:57  IP: 66.232.123.*
    Interesting...
    #Kypros 发表于2007-09-02 11:08:12  IP: 66.232.125.*
    Nice
    #Aristides 发表于2007-09-02 13:38:52  IP: 66.232.123.*
    Nice
    #Yiannos 发表于2007-09-02 15:07:56  IP: 66.232.123.*
    Sorry :(
    #Anastassios 发表于2007-09-02 20:18:11  IP: 201.255.20.*
    Interesting...
    #Sebastianos 发表于2007-09-02 22:31:32  IP: 68.180.195.*
    Cool!
    #Ivan 发表于2007-09-03 03:59:14  IP: 66.232.125.*
    Cool.
    #Arsenios 发表于2007-09-03 05:26:25  IP: 66.232.114.*
    Interesting...
    #Kalinikos 发表于2007-09-03 15:36:14  IP: 66.232.123.*
    Nice
    #Herakles 发表于2007-09-03 19:32:35  IP: 66.232.125.*
    Nice
    #Nikodemos 发表于2007-09-04 01:22:11  IP: 200.251.238.*
    Nice
    #Yioryios 发表于2007-09-04 03:10:00  IP: 66.232.125.*
    Cool.
    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © allin