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

首頁 > 學院 > 開發設計 > 正文

Hibernate 多對多單向關聯

2019-11-10 18:13:25
字體:
來源:轉載
供稿:網友
Hibernate 多對多單向關聯
 
 
一、模型介紹
多個人(Person)對應多個地址(Address)。
一個人可對應多個地址,一個地址也可以對應多個人。 
二、實體(省略getter、setter方法)
 
public class Personnn {
    PRivate int personid;
    private String name;
    private int age;
    private Set addresses=new HashSet();
 
public class Addressnn {
    private int addressid;
    private String addressdetail;
 
三、表模型
 
MySQL> desc person_nn;
+----------+--------------+------+-----+---------+----------------+
| 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 join_nn;
+-----------+---------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| personid  | int(11) | NO   | PRI |         |       |
| addressid | int(11) | NO   | PRI |         |       |
+-----------+---------+------+-----+---------+-------+
 
mysql> desc person_nn;
+----------+--------------+------+-----+---------+----------------+
| Field    | Type         | Null | Key | Default | Extra          |
+----------+--------------+------+-----+---------+----------------+
| personid | int(11)      | NO   | PRI | NULL    | auto_increment |
| name     | varchar(255) | YES  |     | NULL    |                |
| age      | int(11)      | YES  |     | NULL    |                |
+----------+--------------+------+-----+---------+----------------+
 
四、生成的SQL腳本
 
/* Formatted on 2007/08/21 11:13 (QP5 v5.50) */
CREATE TABLE `address_nn` (
  `addressid` int(11) NOT NULL auto_increment,
  `addressdetail` varchar(255) default NULL,
  PRIMARY KEY  (`addressid`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/21 11:14 (QP5 v5.50) */
CREATE TABLE `join_nn` (
  `personid` int(11) NOT NULL,
  `addressid` int(11) NOT NULL,
  PRIMARY KEY  (`personid`,`addressid`),
  KEY `FKAAB98CF5E008E752` (`personid`),
  KEY `FKAAB98CF5239F6A16` (`addressid`),
  CONSTRAINT `FKAAB98CF5239F6A16` FOREIGN KEY (`addressid`) REFERENCES `address_nn` (`addressid`),
  CONSTRAINT `FKAAB98CF5E008E752` FOREIGN KEY (`personid`) REFERENCES `person_nn` (`personid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/21 11:14 (QP5 v5.50) */
CREATE TABLE `person_nn` (
  `personid` int(11) NOT NULL auto_increment,
  `name` varchar(255) default NULL,
  `age` int(11) default NULL,
  PRIMARY KEY  (`personid`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=gbk;
 
五、映射方法
 
<hibernate-mapping>
    <class name="com.lavasoft.dx._n_n.Personnn" table="PERSON_nn">
        <id name="personid">
            <generator class="identity"/>
        </id>
        <property name="name"/>
        <property name="age"/>
        <!--映射集合屬性,join_1ntab是連接表表名-->
        <set name="addresses"
             table="join_nn"
                >
            <!--“column="personid"”確定PERSON_1ntab表關聯到連接表的外鍵列名-->
            <key column="personid"/>
            <!--“column="addressid"”關聯PERSON_1ntab表的Address1ntab對象的id在連接表中的列名-->
            <many-to-many
                    column="addressid"
                    class="com.lavasoft.dx._n_n.Addressnn"/>
        </set>
    </class>
</hibernate-mapping>
 
<hibernate-mapping>
    <class name="com.lavasoft.dx._n_n.Addressnn" table="ADDRESS_nn">
        <id name="addressid">
            <generator class="identity"/>
        </id>
        <property name="addressdetail"/>
    </class>
</hibernate-mapping>
 
 
六、測試方法
 
public class Test_nn {
    public static void main(String[] args){
        Addressnn add1=new Addressnn();
        Addressnn add2=new Addressnn();
        Addressnn add3=new Addressnn();
        Personnn p1=new Personnn();
        Personnn p2=new Personnn();
 
        add1.setAddressdetail("鄭州市經三路");
        add2.setAddressdetail("合肥市宿州路");
        add3.setAddressdetail("北京市長安路");
        p1.setName("wang");
        p1.setAge(30);
        p2.setName("lee");
        p2.setAge(50);
 
        p1.getAddresses().add(add1);
        p1.getAddresses().add(add2);
        p2.getAddresses().add(add2);
        p2.getAddresses().add(add3);
 
        session session= HibernateUtil.getCurrentSession();
        Transaction tx=session.beginTransaction();
        session.save(add1);
        session.save(add2);
        session.save(add3);
        session.save(p1);
        session.save(p2);
        tx.commit();
        HibernateUtil.closeSession();
    }
}
 
七、測試結果
 
1) :正常保存.
        session.save(add1);
        session.save(add2);
        session.save(add3);
        session.save(p1);
        session.save(p2);
 
Hibernate: insert into ADDRESS_nn (addressdetail) values (?)
Hibernate: insert into ADDRESS_nn (addressdetail) values (?)
Hibernate: insert into ADDRESS_nn (addressdetail) values (?)
Hibernate: insert into PERSON_nn (name, age) values (?, ?)
Hibernate: insert into PERSON_nn (name, age) values (?, ?)
Hibernate: insert into join_nn (personid, addressid) values (?, ?)
Hibernate: insert into join_nn (personid, addressid) values (?, ?)
Hibernate: insert into join_nn (personid, addressid) values (?, ?)
Hibernate: insert into join_nn (personid, addressid) values (?, ?)
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人jvid在线播放| 日韩欧美国产免费播放| 国产成人亚洲精品| 欧美激情精品久久久| 欧美一性一乱一交一视频| 亚洲激情中文字幕| 美女视频黄免费的亚洲男人天堂| 亚洲一区二区三区视频播放| 国产精品久久久久久久午夜| 国产精品久久久久久搜索| 欧美黑人极品猛少妇色xxxxx| 欧美猛少妇色xxxxx| 国产亚洲一级高清| 庆余年2免费日韩剧观看大牛| 亚洲第一网中文字幕| 国产一区二区三区欧美| 欧美午夜精品在线| 成人激情av在线| 久久男人av资源网站| 欧美国产一区二区三区| 亚洲桃花岛网站| 精品久久香蕉国产线看观看gif| 91丨九色丨国产在线| yw.139尤物在线精品视频| 91沈先生在线观看| 亚洲人成人99网站| 日韩av理论片| 91精品免费久久久久久久久| 日韩中文字幕在线播放| 欧美日韩在线视频首页| 亚洲香蕉成人av网站在线观看| 亚洲精品视频在线播放| 精品精品国产国产自在线| 日韩av一区在线观看| 亚洲精品欧美日韩| 精品国内自产拍在线观看| 欧美综合国产精品久久丁香| 亚洲激情视频在线观看| 国产精品福利网| 亚洲成人网久久久| 亚洲图片欧洲图片av| 精品国产乱码久久久久久虫虫漫画| 国产精品va在线| 欧美日韩国产精品一区二区三区四区| 91久久夜色精品国产网站| 亚洲bt欧美bt日本bt| 欧美在线亚洲在线| 日韩亚洲欧美中文在线| 91视频免费在线| 亚洲精品大尺度| 亚洲成avwww人| 亚洲免费一在线| 91精品久久久久久综合乱菊| 欧美午夜电影在线| 8050国产精品久久久久久| 国产精品久久久久久久天堂| 国产午夜精品视频| 成人妇女免费播放久久久| 日韩三级影视基地| 精品二区三区线观看| 国产区精品在线观看| 午夜欧美不卡精品aaaaa| 欧美日韩国产在线播放| 中文字幕av一区二区三区谷原希美| 国内精品久久久久久中文字幕| 在线看日韩欧美| 日本久久久久久久久| 国产成人小视频在线观看| 最近2019年日本中文免费字幕| 欧美激情中文字幕乱码免费| 一区二区亚洲欧洲国产日韩| 91在线观看欧美日韩| 久久久久在线观看| 欧美日韩中文字幕| 日韩av一区二区在线| 国产精品69精品一区二区三区| 国产三级精品网站| 日韩女优人人人人射在线视频| 一本色道久久88精品综合| 国产69精品久久久久99| 欧美一级视频一区二区| 97人人爽人人喊人人模波多| 欧美激情在线观看| 伊是香蕉大人久久| 久久高清视频免费| 久久久久亚洲精品国产| 久久精品一区中文字幕| 最好看的2019的中文字幕视频| 日韩经典中文字幕在线观看| 欧美成人精品在线观看| 日韩av电影手机在线观看| 国产亚洲欧洲高清| 色黄久久久久久| 亚洲综合精品伊人久久| 日韩av网站电影| 日韩免费不卡av| 国产精品igao视频| 亚洲成人精品视频在线观看| 亚洲香蕉成人av网站在线观看| 国产成人极品视频| 日韩欧美国产成人| 欧美性生活大片免费观看网址| 深夜精品寂寞黄网站在线观看| 91中文在线视频| 国产精品18久久久久久麻辣| 日韩中文综合网| 久久中国妇女中文字幕| 蜜臀久久99精品久久久久久宅男| 色婷婷综合久久久久| 日韩中文字幕在线观看| 在线观看久久久久久| 午夜精品国产精品大乳美女| 精品爽片免费看久久| 日本久久久久久久| www.久久草.com| 91av在线不卡| 欧美大片va欧美在线播放| 亚洲欧美一区二区三区情侣bbw| 色综合91久久精品中文字幕| 欧美日韩精品中文字幕| 日韩美女av在线免费观看| 91在线播放国产| 色偷偷偷亚洲综合网另类| 日韩中文字幕久久| 亚洲国产高潮在线观看| 日韩精品福利网站| 亚洲男人第一av网站| 久久精品视频中文字幕| 国产精品久久久久久久久久久不卡| 中文字幕亚洲精品| 欧美日韩亚洲一区二区三区| 亚洲美女免费精品视频在线观看| 国产欧美精品va在线观看| 国产精品一区专区欧美日韩| 日韩高清欧美高清| 亚洲一区二区三区视频| 国产欧美 在线欧美| 7m第一福利500精品视频| 91成人性视频| 欧美成人免费全部观看天天性色| 国产精品www网站| 成人性教育视频在线观看| 欧美性猛交xxxx乱大交极品| 精品丝袜一区二区三区| 久久精品久久精品亚洲人| 日韩国产高清污视频在线观看| 国产精品吴梦梦| 精品久久久久久久久久国产| 亚洲激情电影中文字幕| 国产大片精品免费永久看nba| 亚洲激情久久久| 久久精品91久久久久久再现| 欧美性猛交xxxx偷拍洗澡| 国产日韩精品在线播放| 亚洲一区二区黄| 日本不卡高字幕在线2019| 日韩精品一区二区视频| 欧美成人在线网站| 亚洲最大av网站| 日韩电影中文字幕| 国产小视频91| 成人午夜高潮视频| 成人激情视频在线播放| 久久久亚洲国产天美传媒修理工|