亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

Hibernate 多對(duì)多雙向關(guān)聯(lián)

2019-11-10 20:20:51
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
Hibernate 多對(duì)多雙向關(guān)聯(lián)
 
 
一、模型介紹
 
多個(gè)人(Person)對(duì)應(yīng)多個(gè)地址(Address)。一個(gè)人可對(duì)應(yīng)多個(gè)地址,一個(gè)地址也可以對(duì)應(yīng)多個(gè)人。
 
二、實(shí)體(省略getter、setter方法)
 
public class Personnn_sx {
    PRivate int personid;
    private String name;
    private int age;
    private Set addresses=new HashSet();
 
public class Addressnn_sx {
    private int addressid;
    private String addressdetail;
    private Set persons = new HashSet();
 
三、表模型
 
MySQL> desc person_nn_sx;
+----------+--------------+------+-----+---------+----------------+
| Field    | Type         | Null | Key | Default | Extra          |
+----------+--------------+------+-----+---------+----------------+
| personid | int(11)      | NO   | PRI | NULL    | auto_increment |
| name     | varchar(255) | YES  |     | NULL    |                |
| age      | int(11)      | YES  |     | NULL    |                |
+----------+--------------+------+-----+---------+----------------+
 
mysql> desc address_nn_sx;
+---------------+--------------+------+-----+---------+----------------+
| Field         | Type         | Null | Key | Default | Extra          |
+---------------+--------------+------+-----+---------+----------------+
| addressid     | int(11)      | NO   | PRI | NULL    | auto_increment |
| addressdetail | varchar(255) | YES  |     | NULL    |                |
+---------------+--------------+------+-----+---------+----------------+
 
mysql> desc join_nn_sx;
+-----------+---------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| addressid | int(11) | NO   | PRI |         |       |
| personid  | int(11) | NO   | PRI |         |       |
+-----------+---------+------+-----+---------+-------+
 
四、生成的SQL腳本
 
/* Formatted on 2007/08/22 17:59 (QP5 v5.50) */
CREATE TABLE `address_nn_sx` (
  `addressid` int(11) NOT NULL auto_increment,
  `addressdetail` varchar(255) default NULL,
  PRIMARY KEY  (`addressid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/22 17:59 (QP5 v5.50) */
CREATE TABLE `person_nn_sx` (
  `personid` int(11) NOT NULL auto_increment,
  `name` varchar(255) default NULL,
  `age` int(11) default NULL,
  PRIMARY KEY  (`personid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/22 17:59 (QP5 v5.50) */
CREATE TABLE `join_nn_sx` (
  `addressid` int(11) NOT NULL,
  `personid` int(11) NOT NULL,
  PRIMARY KEY  (`personid`,`addressid`),
  KEY `FK6EBBC5EF6C600921` (`personid`),
  KEY `FK6EBBC5EF2A92FF3D` (`addressid`),
  CONSTRAINT `FK6EBBC5EF2A92FF3D` FOREIGN KEY (`addressid`) REFERENCES `address_nn_sx` (`addressid`),
  CONSTRAINT `FK6EBBC5EF6C600921` FOREIGN KEY (`personid`) REFERENCES `person_nn_sx` (`personid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 
五、映射方法
 
<hibernate-mapping>
    <class name="com.lavasoft.sx._n_n.Personnn_sx" table="PERSON_nn_sx">
        <id name="personid">
            <generator class="identity"/>
        </id>
        <property name="name"/>
        <property name="age"/>
        <!--映射集合屬性,關(guān)聯(lián)到持久化類-->
        <!--table="join_1ntab_sx"指定了連接表的名字-->
        <set name="addresses"
             table="join_nn_sx"
             cascade="all">
            <!--column="personid"指定連接表中關(guān)聯(lián)當(dāng)前實(shí)體類的列名-->
            <key column="personid" not-null="true"/>
            <!--column="addressid"是連接表中關(guān)聯(lián)本實(shí)體的外鍵-->
            <many-to-many column="addressid"
                          class="com.lavasoft.sx._n_n.Addressnn_sx"/>
        </set>
    </class>
</hibernate-mapping>
 
<hibernate-mapping>
    <class name="com.lavasoft.sx._n_n.Addressnn_sx"
           table="ADDRESS_nn_sx">
        <id name="addressid">
            <generator class="identity"/>
        </id>
        <property name="addressdetail"/>
        <!--table="join_nn_sx"是雙向多對(duì)多的連接表-->
        <set name="persons"
             inverse="true"
             table="join_nn_sx">
            <!--column="addressid"是連接表中關(guān)聯(lián)本實(shí)體的外鍵-->
            <key column="addressid"/>
            <many-to-many column="personid"
                          class="com.lavasoft.sx._n_n.Personnn_sx"/>
        </set>
    </class>
</hibernate-mapping>
 
六、測(cè)試方法
 
public class Test_nn_sx {
    public static void main(String[] args){
        Addressnn_sx add1=new Addressnn_sx();
        Addressnn_sx add2=new Addressnn_sx();
        Personnn_sx p1=new Personnn_sx();
        Personnn_sx p2=new Personnn_sx();
 
        add1.setAddressdetail("鄭州市經(jīng)三路");
        add2.setAddressdetail("合肥市宿州路");
        p1.setName("wang");
        p1.setAge(30);
        p2.setName("zhang");
        p2.setAge(22);
 
        p1.getAddresses().add(add1);
        p1.getAddresses().add(add2);
        p2.getAddresses().add(add2);
        add1.getPersons().add(p1);
        add2.getPersons().add(p1);
        add2.getPersons().add(p2);
 
 
        session session= HibernateUtil.getCurrentSession();
        Transaction tx=session.beginTransaction();
        session.save(p1);
        session.save(p2);
//        session.saveOrUpdate(add1);
//        session.saveOrUpdate(add2);
        tx.commit();
        HibernateUtil.closeSession();
    }
}
 
七、測(cè)試結(jié)果
 
1) :正常保存.
        session.save(p1);
        session.save(p2);
//        session.saveOrUpdate(add1);
//        session.saveOrUpdate(add2);
 
  Hibernate: insert into PERSON_nn_sx (name, age) values (?, ?)
  Hibernate: insert into ADDRESS_nn_sx (addressdetail) values (?)
  Hibernate: insert into ADDRESS_nn_sx (addressdetail) values (?)
  Hibernate: insert into PERSON_nn_sx (name, age) values (?, ?)
  Hibernate: insert into join_nn_sx (personid, addressid) values (?, ?)
  Hibernate: insert into join_nn_sx (personid, addressid) values (?, ?)
  Hibernate: insert into join_nn_sx (personid, addressid) values (?, ?)

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
青草国产精品久久久久久| 欧美一区二区三区在线观看免费| 亚洲福利视频在线| 黄色成人精品网站| 欧美精品一区二区三区国产精品| 国产成人午夜99999| 中文字幕二三区不卡| 日韩视频免费观看高清完整版在线观看| www.日本不卡| 丰满肉嫩西川结衣av| 亚洲专区第一页| 996久久国产精品线观看| 在线播放高清视频www| 一道本一区二区三区| 亚洲熟女综合色一区二区三区| 久久精品国产精品亚洲色婷婷| 影音先锋国产资源站| 欧美伊人影院| 精品午夜福利视频| 午夜剧场成人观在线视频免费观看| 久久99精品国产91久久来源| 中文在线不卡| 久久艹在线视频| 亚洲精品在线免费看| 日韩一区免费视频| 国产伦精品一区二区三区视频网站| 午夜电影久久久| 18岁网站在线观看| 91精品国产自产拍在线观看蜜| 日日噜噜噜夜夜爽爽狠狠视频| 999国产精品永久免费视频app| 日韩在线一卡二卡| 成+人+亚洲+综合天堂| 国产黄色片网站| 欧美日高清视频| 日韩亚洲第一页| 欧美一区二区观看视频| 国产一区二区在线视频| 成 人 黄 色 小说网站 s色| 18禁男女爽爽爽午夜网站免费| 美女在线不卡| 国产欧美日韩在线看| 日韩免费电影一区| 91中文在线| 国产精品免费无遮挡无码永久视频| 久久99精品久久久久久野外| 亚洲天堂电影| 欧美五级在线观看视频播放| 视频在线这里都是精品| 日韩视频一区二区三区在线播放| 中文字幕免费一区二区三区| 亚洲一区二区三区sesese| 少妇免费毛片久久久久久久久| 亚洲一区中文字幕在线观看| 久久精品国产一区二区三区不卡| 91麻豆精品国产91久久久更新时间| 久久99热只有频精品91密拍| 国产一级做a爰片在线看免费| 久久亚洲国产精品成人av秋霞| 成人综合激情网| 国产一级性片| 欧美日韩亚洲综合在线| 国产一区深夜福利| 国产成人av电影在线| 成人免费淫片95视频观看网站| 亚洲老妇色熟女老太| 国产精品久久久久久久久久久久| 国产a级全部精品| 日韩pacopacomama| 疯狂做受xxxx欧美肥白少妇| 国产高清在线一区| 中文精品视频一区二区在线观看| 国产一级二级三级| 免费无码一区二区三区| 91免费日韩| 国产色综合一区二区三区| 国产 日韩 欧美 综合| 91亚洲精品国偷拍自产在线观看| a视频在线观看| 久久网中文字幕| 精品国产欧美日韩不卡在线观看| 亚洲黄色片视频| 老色鬼在线视频| 99香蕉国产精品偷在线观看| 免费观看一二区视频网站| 免费黄视频在线观看| 国产亚洲激情视频在线| 菠萝蜜视频在线观看一区| 欧美激情免费视频| 亚洲一级一级97网| 欧美日韩电影一区| 日韩av电影院| 黄动漫在线看| 美女爆乳18禁www久久久久久| 日韩视频中文| 欧美国产精品日韩| 日韩一级免费观看| 久久人人妻人人人人妻性色av| 中文在线资源天堂| 妖精视频在线观看| 人人妻人人澡人人爽人人欧美一区| 1区2区3区欧美| 亚洲小说欧美激情另类| 亚洲色图欧美视频| 国产成人精品免费网站| av理论在线观看| 亚洲精品女av网站| 99在线视频观看| 色综合久久久久久久久五月| 日韩午夜av在线| 精产国产伦理一二三区| 国产精品啪视频| 欧美三级电影网站| 亚洲a成人v| 国产免费观看久久| 丝袜诱惑制服诱惑色一区在线观看| 欧美aaaa视频| youjizz.com国产| 久久久久国产美女免费网站| 国产999精品久久久影片官网| 伊人www22综合色| 亚洲国产小视频| 亚洲不卡av不卡一区二区| 久久综合九色综合欧美98| 欧美久久久久中文字幕| 国产综合香蕉五月婷在线| 在线天堂中文| 97精品免费视频| 午夜精品久久久久| 日本精品一区二区三区四区的功能| 亚洲人成网站77777在线观看| 久久久99精品| 久久这里只有精品6| 日韩一区二区三区中文字幕| 欧美高清视频看片在线观看| 欧美特级xxxxbbbb毛片| 午夜精品免费看| 717影院理论午夜伦不卡久久| 337p日本欧洲亚洲大胆张筱雨| 国产精品亚洲成在人线| 国产hs免费高清在线观看| 日韩视频一区二区三区在线播放| 国产青草视频在线观看视频| 丝袜亚洲欧美日韩综合| 日韩欧美精品在线| 88在线观看91蜜桃国自产| 久久噜噜色综合一区二区| 在线观看av网站永久| 韩国中文字幕hd久久精品| 777丰满影院| 免费高清在线观看| 久久一夜天堂av一区二区三区| 成人免费高清完整版在线观看| 欧美无砖专区一中文字| 久久久国产精品久久久| 公侵犯人妻一区二区三区| 理论片中文字幕| 日韩av在线网站| 在线观看福利一区| 69视频在线| 一区二区三区四区在线播放| 91看片淫黄大片一级在线观看| 免费白白视频| 欧美风情在线观看| 亚洲午夜精品一区 二区 三区| 精品日本一区二区三区| 亚洲视频网在线直播| 国产福利在线看| 怡红院怡春院首页| 成人免费在线观看网站| 亚洲片在线资源| 亚洲女人视频| 天天干夜夜操| 久久久久国产美女免费网站| 好吊一区二区三区| 青青操视频在线播放| 在线观看免费黄色片| 国产精品igao激情视频| 日韩精品一二三| 色网站在线视频| 亚洲伊人一本大道中文字幕| 一区二区毛片| 久久久综合久久久| 日韩免费在线视频| 91久久精品国产91性色tv| 神马午夜一区二区| 日韩a级作爱片一二三区免费观看| 国产精品一区二区免费不卡| 色诱av手机版| 国产激情综合| 精品福利视频导航大全| 毛葺葺老太做受视频| 中文字幕在线观看播放| 韩国精品视频在线观看| 精品乱子伦一区二区| 黄色激情在线观看| qvod激情图片| 日韩av一区二区在线| www在线视频观看| 91九色porny在线| 亚洲一区二区三区小说| 在线一区二区三区四区五区| 国产精品久久久久久久久久久久久久久久久久| 2020国产精品| 成人网址大全| 无码人妻av免费一区二区三区| 免费高清在线视频一区·| 亚洲成人在线视频网站| 欧美大片免费观看在线观看网站推荐| 国产私人尤物无码不卡| 国产精品久久久久77777丨| 久久精品aaaaaa毛片| 国产jizzjizz一区二区| 国产精品亚洲一区二区在线观看| 国产精品va在线播放我和闺蜜| 91精品久久久久久久久99蜜臂| 国内精品久久久久影院 日本资源| av动漫免费看| 黄色免费的网站| 国产精品a久久久久久| 国产网红主播福利一区二区| 精品人妻无码中文字幕18禁| 精品久久久久久久久久久久久久| 国产成人三级视频| 中文av资源在线| 国产激情无套内精对白视频| 久热久热免费视频中文字幕777| 国产精品久久久久三级| 国产综合久久久久久| 美洲精品一卡2卡三卡4卡四卡| 超碰在线亚洲| 日韩电影免费在线看| 国产小视频免费在线观看| 一本色道久久综合狠狠躁的番外| 国产无遮挡又黄又爽在线观看| 2021av网| 超碰在线图片| 久久精品电影| 精品视频在线播放| 一本色道a无线码一区v| 午夜探花在线观看| 91九色偷拍| 亚洲欧美精品午睡沙发| av免费看大片| 美日韩中文字幕| 亚洲色图影院| 亚洲天堂男人| 刘亦菲国产毛片bd| 欧美婷婷精品激情| 欧美成人性色生活仑片| 亚洲欧美乱综合图片区小说区| 91免费在线视频观看| 91免费看蜜桃| 狠狠色综合播放一区二区| 在线成人超碰| 中文字幕欧美国产| 精精国产xxxx视频在线播放| 一级做a爱片性色毛片| 久久久久久久久久综合| 嫩草影院一区二区三区| 日本高清视频网站| 黑人巨大精品欧美一区二区小视频| 欧美成人aa大片| 91精品国产色综合久久不卡98| 日韩欧美一级大片| 国产大尺度视频| 精品免费囯产一区二区三区| 国产伦精品一区二区三区高清版| 亚洲一区二区三区加勒比| 黄页在线观看免费| 77导航福利在线| 第一页在线观看| 超碰免费97在线观看| 9i精品福利一区二区三区| 美女在线观看视频一区二区| 97婷婷涩涩精品一区| 真实乱视频国产免费观看| 亚洲成人激情综合网| 亚洲欧美色图小说| 国产亚洲精品精华液| 亚洲欧美电影一区二区| 1000部国产精品成人观看| 日本黄色片视频| 亚洲色图100p| 欧美jizzhd精品欧美满| 日本特黄a级高清免费大片| 欧美日韩一区二区三区69堂| 国产精品久久久久久久久久久久久久久久久| 欧美视频免费看欧美视频| 少妇av片在线观看| 国产中文字幕在线播放| 黑人巨大精品欧美一区二区三区| 欧美在线色视频| 日韩美一区二区三区| 国产精品国产三级国产aⅴ原创| 久久大大胆人体| 亚洲一区二区国产| 成人在线看视频| 欧美日韩国产免费| 欧美片第一页| av色综合网| 在线观看亚洲大片短视频| 日韩电影中文字幕一区| 久热久热免费视频中文字幕777| 亚洲第一综合色| 国产美女自拍| 国产免费无遮挡| 操一操视频一区| 91福利在线播放| 日韩三级精品电影久久久| 日韩欧美一区二区三区在线观看| 四虎影视永久免费观看| 51精品国产| 嫩草一区二区三区| 亚洲色图在线视频| 青青草国产精品一区二区| 国产欧美精品一区二区色综合朱莉| 亚洲日本va午夜在线电影| 免费看av大片| 精品一区毛片| 欧美性xxxx交| 久久久久久久久久久久久久久99| 亚洲成人自拍视频| 久久亚洲精品视频| 顶级黑人搡bbw搡bbbb搡| 成人三级视频在线观看一区二区| 秘密基地免费观看完整版中文| 欧美色综合久久|