<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-124  評論-49  文章-56  trackbacks-0
    一對多關聯映射(one-to-many)
    一對多關聯映射利用了多對一關聯映射原理
      * 多對一關聯映射:在多的一端加和一個外鍵指向一的一端,它維護的關系是多指向一的
      * 一對多關聯映射:在一的一端加和一個外鍵指向多的一端,它維護的關系是一指向多的
    也就是說一對多和多對一的映射策略是一樣的,只是站的角度不同,一般都作成雙項的
    ------------------------------------------------------------------------------
    1 一對多關聯映射(單項Classes--->Student)
    在一一端維護關系的缺點:
      * 如果將t_student表里的classesid這段設置為非空,則無法保存
      * 因為不在student這一端維護關系,所以student不知道是哪個班的
        所以需要發出多余的update語句來更新關系
    <!--
      Classes:                                  Student:
        private int id;                         private int id;
        private String name;             private String name;
        private Set students;//必須用Set
    -->
    <class name="com.my.hibernate.Student">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
    </class>

    <class name="Classes">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <set name="students">
                
    <key column="classesid"/>
                
    <one-to-many class="Student"/>
            
    </set>
    </class>
    public void testSave1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
                Student student1
    =new Student();
                student1.setName(
    "10");
                session.save(student1);
    //先進行save操作
                
                Student student2
    =new Student();
                student2.setName(
    "祖兒");
                session.save(student2);
    //先進行save操作
                
                Set students
    =new HashSet();
                students.add(student1);
                students.add(student2);
                Classes classes
    =new Classes();
                classes.setName(
    "尚學堂");
                classes.setStudents(students);
                session.save(classes);
                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

        
        
    public void testLoad1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
                Classes classes
    =(Classes)session.load(Classes.class3);
                System.out.println(classes.getName());
                Set students
    =classes.getStudents();
                
    for(Iterator iter=students.iterator();iter.hasNext();){
                    Student student
    =(Student)iter.next();
                    System.out.print(student.getName()
    +";");
                }

                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

    2 一對多關聯映射(雙項Classes<--->Student)

    一對多雙向關聯映射:
      * 在一一端的集合上用<key>,在對方表中加入一個外鍵指向一的一端
      * 在多的一端采用<many-to-one>
    注意:<key>標簽指定的外鍵字段必須和<many-to-one>指定的外鍵字段一致,否則引用字段錯誤

    如果在一的一端維護一對多關聯關系,hibernate會發出多余的update語句,所以我們一般在多的一端來維護關聯關系

    關于inverse屬性:
       inverse主要用在一對多和多對多雙向關聯上,inverse可以被設置到集合標簽<set>上,
       默認inverse為 false,所以我們可以從一的一端和多的一端維護關聯關系,
       如果設inverse為true,則我們只能從多的一端來維護關聯關系
    注意:inverse屬性,只影響數據的存儲,也就是持久化。

    inverse和cascade:
      * inverse是關聯關系的控制方向
      * cascade是操作上的連鎖反應

    <!--
      Classes:                                      Student:
        private int id;                               private int id;
        private String name;                   private String name;
        private Set students;//必須用 Set private Classes classes;
    -->
    <class name="Classes">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <set name="students" inverse="true" cascade="all">
                    //cascade屬性:none 不及連 save-update 插入或更新及連 delete刪除及連 all
                
    <key column="classesid"/>
                
    <one-to-many class="Student"/>
            
    </set>
    </class>

    <class name="com.my.hibernate.Student">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <many-to-one name="classes" column="classesid" cascade="save-update"/>
    </class>
    public void testSave1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
    //在多方維護
                Classes classes=new Classes();
                classes.setName(
    "北青");
                
    //session.save(classes);//加了cascade屬性可以不用
                Student student1=new Student();
                student1.setName(
    "黃不接10");
                student1.setClasses(classes);
                session.save(student1);
                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

        
        
    public void testLoad1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
    //從多方讀取
                Student student=(Student)session.load(Student.class5);
                System.out.println(student.getName());
                System.out.println(student.getClasses().getName());
                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

        
        
    public void testSave2(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
    //在一方維護,自動轉向多方
                Classes classes=new Classes();
                classes.setName(
    "尚學堂");
                Student student1
    =new Student();
                student1.setName(
    "10");
                student1.setClasses(classes);
                Student student2
    =new Student();
                student2.setName(
    "祖兒");
                student2.setClasses(classes);
                Set students
    =new HashSet();
                students.add(student1);
                students.add(student2);
                classes.setStudents(students);
        
                session.save(classes);
                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

    多對多關聯映射(單項User---->Role)
    <many-to-many/>標簽
    <set>標簽中加入屬性table="t_user_role"創建關聯表
    <!--
      User:                              Role:
      private int id;                   private int id;
        private String name;     private String name;
        private Set roles;
    -->        
    <class name="com.my.hibernate.Role">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
    </class>

    <class name="User">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <set name="roles" table="t_user_role">
                
    <key column="userid"/>
                
    <many-to-many class="Role" column="roleid"/>
            
    </set>
    </class>
    public void testSave1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                Role role1
    =new Role();
                role1.setName(
    "1111");
                Role role2
    =new Role();
                role2.setName(
    "2222");
                Role role3
    =new Role();
                role3.setName(
    "3333");
                session.save(role1);
                session.save(role2);
                session.save(role3);
                
                User user1
    =new User();
                user1.setName(
    "user1");
                Set user1Role
    =new HashSet();
                user1Role.add(role1);
                user1Role.add(role2);
                user1.setRoles(user1Role);
                
                User user2
    =new User();
                user2.setName(
    "user2");
                Set user2Role
    =new HashSet();
                user2Role.add(role2);
                user2Role.add(role3);
                user2.setRoles(user2Role);
                
                User user3
    =new User();
                user3.setName(
    "user3");
                Set user3Role
    =new HashSet();
                user3Role.add(role2);
                user3Role.add(role3);
                user3Role.add(role1);
                user3.setRoles(user3Role);
                
                session.save(user1);
                session.save(user2);
                session.save(user3);
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

        
        
    public void testLoad1(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
                User u1
    =(User)session.load(User.class1);
                System.out.println(u1.getName());
                
    for(Iterator iter=u1.getRoles().iterator();iter.hasNext();){
                    System.out.println(((Role)iter.next()).getName());
                }

                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

    多對多關聯映射(雙項User<---->Role)
    <many-to-many/>標簽
    映射方法:
       <set name="users" table="t_user_role" order-by="userid">
        <key column="roleid"/>
        <many-to-many class="com.my.hibernate.User" column="userid"/>
        </set>
    table屬性值必須和單向關聯的table屬性值一致
    <key>中column屬性值要與單向關聯中的<many-to-many>標簽中的column屬性值一致
    <many-to-many>中column屬性值要與單向關聯中的<key>標簽中的column屬性值一致
    <!--
      User:                                  Role:
      private int id;                   private int id;
        private String name;     private String name;
        private Set roles;           private Set users;
    -->
        
    <class name="com.my.hibernate.Role">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <set name="users" table="t_user_role" order-by="userid">
                
    <key column="roleid"/>
                
    <many-to-many class="com.my.hibernate.User" column="userid"/>
            
    </set>
        
    </class>
        
        
    <class name="User">
            
    <id name="id">
                
    <generator class="native"/>
            
    </id>
            
    <property name="name"/>
            
    <set name="roles" table="t_user_role">
                
    <key column="userid"/>
                
    <many-to-many class="Role" column="roleid"/>
            
    </set>
        
    </class>
    public void testLoad2(){
            Session session
    =null;
            
    try{
                session
    =HibernateUtils.getSession();
                session.beginTransaction();
                
                Role role
    =(Role)session.load(Role.class3);
                System.out.println(role.getName());
                
    for(Iterator iter=role.getUsers().iterator();iter.hasNext();){
                    System.out.println(((User)iter.next()).getName());
                }

                
                session.getTransaction().commit();
            }
    catch(Exception e){
                session.getTransaction().rollback();
                e.printStackTrace();
            }
    finally{
                HibernateUtils.closeSession(session);
            }

        }

    set 不可重復
    posted on 2009-11-03 16:04 junly 閱讀(654) 評論(0)  編輯  收藏 所屬分類: hibernate/orm
    主站蜘蛛池模板: 亚洲人成日本在线观看| 深夜福利在线免费观看| 亚洲大尺度无码无码专区| 免费91最新地址永久入口| 亚洲成人一级电影| 国产91久久久久久久免费| 三年在线观看免费观看完整版中文| 久久青青草原亚洲av无码app | 91嫩草国产在线观看免费| 精品成人一区二区三区免费视频| 亚洲阿v天堂在线| 国产精品高清免费网站| 亚洲网站免费观看| 四虎永久精品免费观看| 18未年禁止免费观看| 猫咪免费人成网站在线观看入口| 亚洲小视频在线观看| 人人狠狠综合久久亚洲高清| 2021国内精品久久久久精免费| 羞羞漫画登录页面免费| 亚洲欧洲精品国产区| 亚洲午夜成人精品电影在线观看| 色片在线免费观看| 中文字幕免费在线看线人动作大片 | 亚洲AV无码之日韩精品| 四虎在线视频免费观看视频| yellow视频免费看| 亚洲精品精华液一区二区 | 亚美影视免费在线观看| 亚洲一区二区三区写真 | 亚洲一本一道一区二区三区| 亚洲AV乱码久久精品蜜桃| 免费在线视频一区| 免费观看黄网站在线播放| 久久久久久久99精品免费| 九九免费精品视频在这里| 亚洲欧洲国产综合AV无码久久 | 黄色网址免费在线观看| 亚洲av日韩专区在线观看| 亚洲人成免费电影| 亚洲狠狠ady亚洲精品大秀|