Heim > Java > javaLernprogramm > Hauptteil

Detaillierte Erläuterung der Mehrtabellenoperationen in Javaee

零下一度
Freigeben: 2017-06-25 10:35:58
Original
2330 Leute haben es durchsucht

Eins, eins-zu-viele|viele-zu-eins

1. Beziehungsausdruck

Ausdruck in der Tabelle

 

Ausdruck in Entität

Ausdruck in Orm-Metadaten

One-to -viele

        <!-- 集合,一对多关系,在配置文件中配置 --><!-- 
            name属性:集合属性名
            column属性: 外键列名
            class属性: 与我关联的对象完整类名         --><set name="linkMens" inverse="true" cascade="delete"  ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
Nach dem Login kopieren

Viele-zu-eins

        <!-- 多对一 --><!-- 
            name属性:引用属性名
            column属性: 外键列名
            class属性: 与我关联的对象完整类名         --><many-to-one name="customer" column="lkm_cust_id" class="Customer"  ></many-to-one>
Nach dem Login kopieren

2 🎜>Vorgangsbezogene Attribute

        //3操作Customer c = new Customer();
        c.setCust_name("传智播客");
        
        LinkMan lm1 = new LinkMan();
        lm1.setLkm_name("黎活明");
        
        LinkMan lm2 = new LinkMan();
        lm2.setLkm_name("刘悦东");        //表达一对多,客户下有多个联系人        c.getLinkMens().add(lm1);
        c.getLinkMens().add(lm2);        //表达对对对,联系人属于哪个客户        lm1.setCustomer(c);
        lm2.setCustomer(c);
        
        
        session.save(c);
        session.save(lm1);
        session.save(lm2);
Nach dem Login kopieren
3. Erweiterter Betrieb

 

Kaskadenbetrieb

         <span style="color: #008000"><!--</span><span style="color: #008000"> 
             级联操作:    cascade
                 save-update: 级联保存更新
                 delete:级联删除
                 all:save-update+delete
             级联操作: 简化操作.目的就是为了少些两行代码.          </span><span style="color: #008000">--><br></span>
Nach dem Login kopieren
Fazit: Vereinfachte Bedienung. Speichern-Aktualisieren erforderlich, Löschen wird nicht empfohlen
        <set name="linkMens" inverse="true" cascade="delete"  ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
Nach dem Login kopieren
Beziehungspflege

Beim Speichern pflegen beide Parteien die Beziehung zweimal, was offensichtlich überflüssig ist >

2. Viele-zu-viele
          <!-- inverse属性: 配置关系是否维护. 
                  true: customer不维护关系
                  false(默认值): customer维护关系
                  
              inverse属性: 性能优化.提高关系维护的性能.
              原则: 无论怎么放弃,总有一方必须要维护关系.
              一对多关系中: 一的一方放弃.也只能一的一方放弃.多的一方不能放弃.          --><set name="linkMens" inverse="true" cascade="delete"  ><key column="lkm_cust_id" ></key><one-to-many class="LinkMan" /></set>
Nach dem Login kopieren

1 >

Ausdrücke in Tabellen

Objekte

>

2. Vorgang

Vorgangszugehörige Attribute

        <!-- 多对多关系表达 --><!-- 
            name: 集合属性名
            table: 配置中间表名
            key
             |-column:外键,别人引用"我"的外键列名
             class: 我与哪个类是多对多关系
             column:外键.我引用比人的外键列名         --> <!-- cascade级联操作:
                     save-update: 级联保存更新
                     delete:级联删除
                     all:级联保存更新+级联删除
             结论: cascade简化代码书写.该属性使不使用无所谓. 建议要用只用save-update.
                  如果使用delete操作太过危险.尤其在多对多中.不建议使用.                      --><set name="roles" table="sys_user_role" cascade="save-update" ><key column="user_id" ></key><many-to-many class="Role" column="role_id" ></many-to-many></set>
Nach dem Login kopieren
3

inverses Attribut

Kaskadenattribut

        //3> 用户表达关系        u1.getRoles().add(r1);
        u1.getRoles().add(r2);
        
        u2.getRoles().add(r1);
        u2.getRoles().add(r2);        //4> 角色表达关系        r1.getUsers().add(u1);
        r1.getUsers().add(u2);
        
        r2.getUsers().add(u1);
        r2.getUsers().add(u2);        //5> 调用Save方法一次保存        session.save(u1);
        session.save(u2);
        session.save(r1);
        session.save(r2);
Nach dem Login kopieren

3. Übung: Kontakte hinzufügen

    <!-- 使用inverse属性
            true: 放弃维护外键关系
            false(默认值):维护关系
            
        结论: 将来在开发中,如果遇到多对多关系.一定要选择一方放弃维护关系.
             一般谁来放弃要看业务方向. 例如录入员工时,需要为员工指定所属角色.
             那么业务方向就是由员工维护角色. 角色不需要维护与员工关系.角色放弃维护         -->        <set name="users" table="sys_user_role" inverse="true" ><key column="role_id" ></key><many-to-many class="User" column="user_id" ></many-to-many></set>
Nach dem Login kopieren

         <!-- cascade级联操作:
                     save-update: 级联保存更新
                     delete:级联删除
                     all:级联保存更新+级联删除
             结论: cascade简化代码书写.该属性使不使用无所谓. 建议要用只用save-update.
                  如果使用delete操作太过危险.尤其在多对多中.不建议使用.                      --><set name="roles" table="sys_user_role" cascade="save-update" ><key column="user_id" ></key><many-to-many class="Role" column="role_id" ></many-to-many></set>
Nach dem Login kopieren
Servlet:

Service:

dao:

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Mehrtabellenoperationen in Javaee. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!