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

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

Hibernate 一對多連接表單向關聯

2019-11-10 17:30:30
字體:
來源:轉載
供稿:網友
Hibernate 一對多連接表單向關聯
 
 
 
一、模型介紹
 
一個人(Person)對應多個地址(Address),比如家庭地址、公司地址。
 
二、實體(省略getter、setter方法)
 
public class Person1ntab {
    PRivate int personid;
    private String name;
    private int age;
    private Set addresses=new HashSet();
 
public class Address1nfk implements Serializable {
    private int addressid;
    private String addressdetail;
 
三、表模型
 
MySQL> desc join_1ntab;
+-----------+---------+------+-----+---------+-------+
| Field     | Type    | Null | Key | Default | Extra |
+-----------+---------+------+-----+---------+-------+
| personid  | int(11) | NO   | PRI |         |       |
| addressid | int(11) | NO   | PRI |         |       |
+-----------+---------+------+-----+---------+-------+
 
mysql> desc person_1ntab;
+----------+--------------+------+-----+---------+----------------+
| 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_1ntab;
+---------------+--------------+------+-----+---------+----------------+
| Field         | Type         | Null | Key | Default | Extra          |
+---------------+--------------+------+-----+---------+----------------+
| addressid     | int(11)      | NO   | PRI | NULL    | auto_increment |
| addressdetail | varchar(255) | YES  |     | NULL    |                |
+---------------+--------------+------+-----+---------+----------------+
 
四、生成的SQL腳本
 
/* Formatted on 2007/08/21 10:58 (QP5 v5.50) */
CREATE TABLE `address_1ntab` (
  `addressid` int(11) NOT NULL auto_increment,
  `addressdetail` varchar(255) default NULL,
  PRIMARY KEY  (`addressid`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/21 10:58 (QP5 v5.50) */
CREATE TABLE `join_1ntab` (
  `personid` int(11) NOT NULL,
  `addressid` int(11) NOT NULL,
  PRIMARY KEY  (`personid`,`addressid`),
  UNIQUE KEY `addressid` (`addressid`),
  KEY `FK6B6078C3C8DF5BFF` (`personid`),
  KEY `FK6B6078C3C2B11347` (`addressid`),
  CONSTRAINT `FK6B6078C3C2B11347` FOREIGN KEY (`addressid`) REFERENCES `address_1ntab` (`addressid`),
  CONSTRAINT `FK6B6078C3C8DF5BFF` FOREIGN KEY (`personid`) REFERENCES `person_1ntab` (`personid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
 
/* Formatted on 2007/08/21 10:58 (QP5 v5.50) */
CREATE TABLE `person_1ntab` (
  `personid` int(11) NOT NULL auto_increment,
  `name` varchar(255) default NULL,
  `age` int(11) default NULL,
  PRIMARY KEY  (`personid`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=gbk;
 
 
五、映射方法
 
<hibernate-mapping>
    <class name="com.lavasoft.dx._1_n_tab.Person1ntab" table="PERSON_1ntab">
        <id name="personid">
            <generator class="identity"/>
        </id>
        <property name="name"/>
        <property name="age"/>
        <!--映射集合屬性,join_1ntab是連接表表名-->
        <set name="addresses"
             table="join_1ntab"
                >
            <!--“column="personid"”確定PERSON_1ntab表關聯到連接表的外鍵列名-->
            <key column="personid"/>
            <!--“column="addressid"”關聯PERSON_1ntab表的Address1ntab對象的id在連接表中的列名-->
            <!--“unique="true"表示1-N,Person1ntab是1,Address1ntab是多”-->
            <many-to-many
                    column="addressid"
                    unique="true"
                    class="com.lavasoft.dx._1_n_tab.Address1ntab"/>
        </set>
    </class>
</hibernate-mapping>
 
<hibernate-mapping>
    <class name="com.lavasoft.dx._1_n_tab.Address1ntab" table="ADDRESS_1ntab">
        <id name="addressid">
            <generator class="identity"/>
        </id>
        <property name="addressdetail"/>
    </class>
</hibernate-mapping>
 
 
六、測試方法
 
public class Test_1ntab {
    public static void main(String[] args){
        Address1ntab add1=new Address1ntab();
        Address1ntab add2=new Address1ntab();
        Address1ntab add3=new Address1ntab();
        Person1ntab p1=new Person1ntab();
        Person1ntab p2=new Person1ntab();
 
        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 PERSON_1nfk (name, age) values (?, ?)
Hibernate: insert into ADDRESS_1nfk (addressdetail) values (?)
Hibernate: insert into ADDRESS_1nfk (addressdetail) values (?)
Hibernate: update ADDRESS_1nfk set personid=? where addressid=?
Hibernate: update ADDRESS_1nfk set personid=? where addressid=?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲高清在线观看| 欧美成人午夜剧场免费观看| 欧美激情精品久久久久久| 伊人一区二区三区久久精品| 欧美乱妇40p| 久久久www成人免费精品张筱雨| 欧美最顶级丰满的aⅴ艳星| 黑人精品xxx一区一二区| 欧美成人免费观看| 国产精品网红福利| 久久五月天色综合| 成人在线一区二区| 91久久国产婷婷一区二区| 亚洲欧美自拍一区| 久久免费视频在线| 欧美日韩中文字幕在线| 美女视频黄免费的亚洲男人天堂| 欧美精品一区二区免费| 国产成人精品免高潮费视频| 成人黄色激情网| 中文字幕一精品亚洲无线一区| 91精品视频在线看| 亚洲已满18点击进入在线看片| 国产午夜精品一区二区三区| 欧美国产视频一区二区| 国产精品444| 日韩中文字幕在线免费观看| 欧美日韩中文字幕综合视频| 91国产在线精品| 久久久久久中文字幕| 欧美激情第三页| 久久精品国产2020观看福利| 欧美精品在线第一页| 国产98色在线| 精品日韩美女的视频高清| 久久久电影免费观看完整版| 日韩精品福利在线| 在线播放日韩专区| 国产v综合ⅴ日韩v欧美大片| 欧美性极品xxxx做受| 97在线视频国产| 国产成人综合精品在线| 久久国产精品影片| 国产精品一区二区三区久久久| 日韩成人中文字幕在线观看| 精品久久久久久久久久ntr影视| 久久久国产精品亚洲一区| 成人免费淫片视频软件| 国产美女直播视频一区| 亚洲欧洲午夜一线一品| 国产精品高精视频免费| 欧美丝袜一区二区三区| 久久精品青青大伊人av| 欧美肥老妇视频| 欧美国产极速在线| 亚洲精品成人久久电影| 高清在线视频日韩欧美| 日韩美女中文字幕| 日韩精品福利在线| 国产成人av网| 亚洲最大成人免费视频| 亚洲色图综合网| 国产亚洲精品美女久久久| 神马久久久久久| 91精品国产综合久久香蕉最新版| 国产精品一区二区三区毛片淫片| 久久久久久久久久久免费精品| 国产欧美日韩综合精品| 欧洲成人午夜免费大片| 亚洲第一精品福利| 中文字幕国内精品| 亚洲美女精品久久| 久久91精品国产91久久跳| 国产女精品视频网站免费| 国产成+人+综合+亚洲欧洲| 国产精品777| 成人免费视频网址| 午夜精品久久久久久久久久久久久| 欧美高清视频在线| 亚洲高清av在线| www.亚洲免费视频| 国产精品亚发布| 日韩精品极品视频免费观看| 中文字幕视频一区二区在线有码| 日本欧美精品在线| 欧美性xxxxx| 91精品国产91久久久| 亚洲一级黄色av| 日本精品久久久久久久| 中日韩美女免费视频网址在线观看| 亚洲日韩中文字幕在线播放| 日韩av影视综合网| 日韩精品极品毛片系列视频| 中文字幕少妇一区二区三区| 成人国产在线激情| 成人午夜激情免费视频| 久久99视频精品| 国产日产欧美a一级在线| 精品国产区一区二区三区在线观看| 日韩网站免费观看| 亚洲欧美日本精品| 久久久国产成人精品| 久久久av免费| 97视频网站入口| 欧美丝袜美女中出在线| 欧美亚洲激情视频| 美女啪啪无遮挡免费久久网站| 亚洲免费伊人电影在线观看av| 在线成人一区二区| 日韩a**中文字幕| 91老司机在线| 亚洲免费影视第一页| 91精品国产综合久久香蕉922| 欧美午夜性色大片在线观看| 国产区精品视频| 国产精品白丝av嫩草影院| 欧美激情精品久久久| 日韩免费中文字幕| 久久影视电视剧凤归四时歌| 91tv亚洲精品香蕉国产一区7ujn| 亚洲综合日韩在线| 久久精品国产96久久久香蕉| 夜夜狂射影院欧美极品| 2019国产精品自在线拍国产不卡| 中日韩美女免费视频网址在线观看| 日本一区二三区好的精华液| 亚洲国产欧美在线成人app| 大荫蒂欧美视频另类xxxx| 欧美巨猛xxxx猛交黑人97人| 国产精品久久久久久久美男| 国产精品无码专区在线观看| 久久久久久久久亚洲| 欧美大肥婆大肥bbbbb| 97在线视频国产| 91tv亚洲精品香蕉国产一区7ujn| 国产成人精品免高潮费视频| 国产一区私人高清影院| 成人国产精品色哟哟| 成人高清视频观看www| 欧美黑人极品猛少妇色xxxxx| 成人av在线天堂| 欧美性极品少妇精品网站| 久久久久久伊人| 日韩在线国产精品| 亚洲性视频网址| 69av成年福利视频| 日韩电影第一页| 粉嫩av一区二区三区免费野| 隔壁老王国产在线精品| 亚洲男人天堂网| 精品人伦一区二区三区蜜桃网站| 日韩国产高清视频在线| 成人午夜一级二级三级| 欧美视频免费在线观看| 国产香蕉一区二区三区在线视频| 久久久久久成人| 中文字幕一精品亚洲无线一区| 欧美亚洲国产成人精品| 国产精品aaa| 欧美精品手机在线| 亚洲精品资源美女情侣酒店| 精品国产91久久久久久| 中文字幕视频在线免费欧美日韩综合在线看| 亚洲精品97久久|