日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國(guó)內(nèi)最全I(xiàn)T社區(qū)平臺(tái) 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁(yè) > 互聯(lián)網(wǎng) > Hibernate關(guān)聯(lián)關(guān)系映射之一對(duì)一關(guān)聯(lián)關(guān)系

Hibernate關(guān)聯(lián)關(guān)系映射之一對(duì)一關(guān)聯(lián)關(guān)系

來(lái)源:程序員人生   發(fā)布時(shí)間:2014-10-21 08:00:00 閱讀次數(shù):3078次

人和身份證之間就是一個(gè)典型的一對(duì)一關(guān)聯(lián)關(guān)系。實(shí)現(xiàn)一對(duì)一關(guān)聯(lián)關(guān)系映射的方式有兩種一種是基于外鍵,一種是基于主鍵,下面我們先看基于外鍵的關(guān)聯(lián)方式

首先看他們的實(shí)體類

Person類

package entity; public class Person { private Integer id; private String name; private IdCard idCard; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public IdCard getIdCard() { return idCard; } public void setIdCard(IdCard idCard) { this.idCard = idCard; } }

然后看IdCard類

package entity; public class IdCard { private Integer id; private String number; private Person person; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number; } public Person getPerson() { return person; } public void setPerson(Person person) { this.person = person; } }

這里在Person類和IdCard類中分別有一個(gè)對(duì)方類型的屬性。

然后看他們之間的關(guān)聯(lián)關(guān)系映射,首先看Person.hbm.xml

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="entity.Person" table="Person" schema="MYHR"> <id name="id" type="int"> <column name="ID" /> <generator class="assigned" /> </id> <property name="name" type="string"> <column name="NAME" not-null="true" /> </property> <!-- idCard屬性,IdCard類型,表達(dá)本類與IdCard的一對(duì)一關(guān)聯(lián) --> <!-- 采用基于外鍵的一對(duì)一,本方無(wú)外鍵方 --> <!-- property-ref屬性:對(duì)方映射中外鍵類對(duì)應(yīng)的屬性名 --> <one-to-one name="idCard" class="entity.IdCard" property-ref="person"> </one-to-one> </class> </hibernate-mapping>

然后看一下IdCard.hbm.xml文檔

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping> <class name="entity.IdCard" table="IdCard" schema="MYHR"> <id name="id"> <column name="ID"/> <generator class="assigned" /> </id> <property name="number"> <column name="NAME" not-null="true" /> </property> <!-- person屬性,Person類型,表示與Person類的一對(duì)一關(guān)聯(lián)關(guān)系 --> <!-- 采用基于外鍵的一對(duì)一關(guān)聯(lián)方式,本方有外鍵 --> <many-to-one name="person" column="personId" class="entity.Person" unique="true"></many-to-one> </class> </hibernate-mapping>

這樣Person和IdCard之間的一對(duì)一關(guān)聯(lián)關(guān)系就搭建好了,然后看一下測(cè)試類

package test; import static org.junit.Assert.*; import org.hibernate.Session; import org.hibernate.Transaction; import entity.IdCard; import entity.Person; import factory.HibernateSessionFactory; public class Test { private Session session = null; private Transaction tran = null; @org.junit.Test public void save() { session = HibernateSessionFactory.getSession(); tran = session.beginTransaction(); try{ //新建對(duì)象 Person p = new Person(); p.setId(1); p.setName("張三"); IdCard idCard = new IdCard(); idCard.setId(1); idCard.setNumber("10001"); p.setIdCard(idCard); idCard.setPerson(p); session.save(p); session.save(idCard); tran.commit(); }catch(Exception e){ tran.rollback(); } } @org.junit.Test public void Get() { session = HibernateSessionFactory.getSession(); tran = session.beginTransaction(); try{ Person person = (Person) session.get(Person.class, 1); IdCard idCard = person.getIdCard(); System.out.println(person.getName()+"身份證號(hào):"+idCard.getNumber()); tran.commit(); }catch(Exception e){ tran.rollback(); } } //解除關(guān)系 @org.junit.Test public void RemoveRelation() { session = HibernateSessionFactory.getSession(); tran = session.beginTransaction(); try{ //從有外鍵方接觸關(guān)聯(lián)關(guān)系可以,不可以從無(wú)外鍵方解除 IdCard idCard = (IdCard)session.get(IdCard.class, 1); idCard.setPerson(null); tran.commit(); }catch(Exception e){ tran.rollback(); } } //刪除 @org.junit.Test public void DeleteRelation() { session = HibernateSessionFactory.getSession(); tran = session.beginTransaction(); try{ //如果沒(méi)有關(guān)聯(lián)對(duì)方,可以直接刪除。 //如果有關(guān)聯(lián)對(duì)方,且可以維護(hù)關(guān)聯(lián)關(guān)系,他就會(huì)先刪除關(guān)聯(lián)關(guān)系,在刪除自己。 //如果有關(guān)聯(lián)關(guān)系,且不能維護(hù)關(guān)聯(lián)關(guān)系,所以會(huì)執(zhí)行刪除自己,并且拋出異常。 IdCard idCard = (IdCard)session.get(IdCard.class, 1); session.delete(idCard); tran.commit(); }catch(Exception e){ tran.rollback(); } } }

這就是基于外鍵方式,基于主鍵的方式只需要在以上基礎(chǔ)修改一下映射文件即可,下面分別看一下修改后的映射文件

首先看Person.hbm.xml

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="entity"> <class name="entity.Person" table="Person" schema="MYHR"> <id name="id" type="int"> <column name="ID" /> <generator class="assigned" /> </id> <property name="name" type="string"> <column name="NAME" not-null="true" /> </property> <!-- idCard屬性,IdCard類型,表達(dá)本類與IdCard的一對(duì)一關(guān)聯(lián) --> <!-- 采用基于主鍵的一對(duì)一,本方無(wú)外鍵方 --> <one-to-one name="idCard" class="entity.IdCard"/> </class> </hibernate-mapping>

然后看IdCard.hbm.xml

<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="entity"> <class name="entity.IdCard" table="IdCard" schema="MYHR"> <id name="id" type="int"> <column name="ID" /> <!-- 當(dāng)使用基于主鍵的一對(duì)一映射時(shí),有外鍵方的主鍵生成策略是foreign, --> <!-- 參數(shù)property:生成主鍵值時(shí)所根據(jù)的對(duì)象 --> <generator class="foreign"> <param name="property">person</param> </generator> </id> <property name="number" type="string"> <column name="NAME" not-null="true" /> </property> <!-- person屬性,Person類型,表示與Person類的一對(duì)一關(guān)聯(lián)關(guān)系 --> <!-- 采用基于主鍵的一對(duì)一關(guān)聯(lián)方式,本方有外鍵 --> <one-to-one name="person" class="entity.Person" constrained="true" /> </class> </hibernate-mapping>

 

生活不易,碼農(nóng)辛苦
如果您覺(jué)得本網(wǎng)站對(duì)您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈(zèng)
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: 九色官网| 欧美色综合天天久久综合精品 | 久久嫩草精品久久久精品才艺表演 | 精品一区二区电影 | 一区二区三区高清不卡 | 久久久久久免费毛片 | 毛片av在线| 最近最好最新2019中文字幕免费 | 免费高清av | 日韩免费网| 日韩国产一区二区三区 | 欧美高清视频一区 | 婷婷综合一区 | 久久黄色 | 日韩av网站在线观看 | 国产成人一区 | 99视频一区二区 | 久久精品国内 | 国产成人精品一区二 | 精品成人久久久 | 欧美特级视频 | 午夜精品久久久久久久久久久久久 | 欧美日韩在线免费 | 亚洲视频精品 | 男女午夜视频 | 1000部精品久久久久久久久 | 欧美日韩精品一二三区 | 欧美一区二区三区精品免费 | 亚洲第一天堂 | 亚洲乱码国产乱码精品精 | 欧美成人免费网站 | 亚洲视频影院 | 黄色免费看网站 | 亚洲三级电影网 | 国产在线二区 | 久久精品国产欧美亚洲人人爽 | 99爱免费视频 | 日韩精品一区二区在线观看 | 黑人性视频 | 九九九久久国产免费 | 成年人在线看片 |