Hibernate 之实体类之间的关系

来源:互联网 发布:grace评分软件中文版 编辑:程序博客网 时间:2024/05/21 08:57

1.一对一:如一个公民对应一张身份证。

package com.zking.entity;public class User {private int uid;private String uname;private Card card;public Card getCard() {return card;}public void setCard(Card card) {this.card = card;}public User() {super();}public User(String uname) {super();this.uname = uname;}public int getUid() {return uid;}public void setUid(int uid) {this.uid = uid;}public String getUname() {return uname;}public void setUname(String uname) {this.uname = uname;}}

package com.zking.entity;public class Card {private int uid;private String cnum;private User user;public User getUser() {return user;}public void setUser(User user) {this.user = user;}public Card() {super();}public Card(String cnum) {super();this.cnum = cnum;}public int getUid() {return uid;}public void setUid(int uid) {this.uid = uid;}public String getCnum() {return cnum;}public void setCnum(String cnum) {this.cnum = cnum;}}
User.hbm.xml:
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:56:46 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.User" table="USER">        <id name="uid" type="int">            <column name="UID" />            <generator class="native"/>        </id>        <property name="uname" type="java.lang.String">            <column name="UNAME" />        </property>        <one-to-one name="card" class="com.zking.entity.Card" cascade="all-delete-orphan"></one-to-one>    </class></hibernate-mapping>
Card.hbm.xml
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:56:46 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.Card" table="CARD">        <id name="uid" type="int">            <column name="UID" />            <generator class="foreign">            <param name="property">user</param>            </generator>        </id>        <property name="cnum" type="java.lang.String">            <column name="CNUM" />        </property>        <one-to-one name="user" class="com.zking.entity.User"></one-to-one>    </class></hibernate-mapping>

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration>    <session-factory>        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>        <property name="hibernate.connection.password">password</property>        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/student</property>        <property name="hibernate.connection.username">root</property>        <!-- 打印sql语句 -->        <property name="show_sql">true</property><property name="format_sql">true</property>            <!-- map关联两张表 -->        <mapping resource="com/zking/entity/Card.hbm.xml"/>        <mapping resource="com/zking/entity/User.hbm.xml"/>    </session-factory></hibernate-configuration>

2.一对多:省与市

package com.zking.entity;import java.util.HashSet;import java.util.Set;public class Province {private int pid;private String pname;private Set<City> cities=new HashSet<City>();public Set<City> getCities() {return cities;}public void setCities(Set<City> cities) {this.cities = cities;}public Province() {super();}public Province(String pname) {super();this.pname = pname;}public int getPid() {return pid;}public void setPid(int pid) {this.pid = pid;}public String getPname() {return pname;}public void setPname(String pname) {this.pname = pname;}}
package com.zking.entity;public class City {private int cid;private String cname;//private int pid;private Province province;public Province getProvince() {return province;}public void setProvince(Province province) {this.province = province;}public City() {super();// TODO Auto-generated constructor stub}public City(String cname) {super();this.cname = cname;}public int getCid() {return cid;}public void setCid(int cid) {this.cid = cid;}public String getCname() {return cname;}public void setCname(String cname) {this.cname = cname;}//public int getPid() {//return pid;//}//public void setPid(int pid) {//this.pid = pid;//}}
Province.hbm.xml
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:14:11 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.Province" table="PROVINCE">        <id name="pid" type="int">            <column name="PID" />            <generator class="native" />        </id>        <property name="pname" type="java.lang.String">            <column name="PNAME" />        </property>                <set name="cities" table="city" cascade="save-update">        <key column="pid"></key>        <one-to-many class="com.zking.entity.City"/>        </set>                    </class></hibernate-mapping>

City.hbm.xml
<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:14:11 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.City" table="CITY">        <id name="cid" type="int">            <column name="CID" />            <generator class="native" />        </id>        <property name="cname" type="java.lang.String">            <column name="CNAME" />        </property>       <!--  <property name="pid" type="int">            <column name="PID" />        </property> -->        <many-to-one name="province" class="com.zking.entity.Province" column="pid"></many-to-one>    </class></hibernate-mapping>
hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration>    <session-factory>        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>        <property name="hibernate.connection.password">password</property>        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>        <property name="hibernate.connection.username">root</property><property name="show_sql">true</property>     <property name="format_sql">true</property>        <mapping resource="com/zking/entity/Province.hbm.xml"/>        <mapping resource="com/zking/entity/City.hbm.xml"/>     </session-factory></hibernate-configuration>

package com.zking.test;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.junit.After;import org.junit.Before;import org.junit.Test;import com.zking.entity.Card;import com.zking.entity.City;import com.zking.entity.Province;import com.zking.entity.User;public class TestOneToMany {private SessionFactory sessionFactory;private Session session;private Transaction transaction;@Beforepublic void before(){Configuration configuration=new Configuration().configure();sessionFactory = configuration.buildSessionFactory();session = sessionFactory.openSession();transaction = session.beginTransaction();}@Afterpublic void after(){transaction.commit();session.close();sessionFactory.close();}public void testAdd(){Province province=new Province("湖南省");City city1=new City("长沙市");City city2=new City("娄底市");City city3=new City("其他市");province.getCities().add(city1);province.getCities().add(city2);province.getCities().add(city3);city1.setProvince(province);city2.setProvince(province);city3.setProvince(province);session.save(province);}}
3.多对多: 权限表

package com.zking.entity;import java.util.HashSet;import java.util.Set;public class Users {private int uid;private String uname;private Set<Roles> roles=new HashSet<Roles>();public Set<Roles> getRoles() {return roles;}public void setRoles(Set<Roles> roles) {this.roles = roles;}public Users() {super();// TODO Auto-generated constructor stub}public Users(String uname) {super();this.uname = uname;}public int getUid() {return uid;}public void setUid(int uid) {this.uid = uid;}public String getUname() {return uname;}public void setUname(String uname) {this.uname = uname;}}

package com.zking.entity;import java.util.HashSet;import java.util.Set;public class Roles {private int rid;private String rname;private Set<Users> users=new HashSet<Users>();public Set<Users> getUsers() {return users;}public void setUsers(Set<Users> users) {this.users = users;}public Roles() {super();}public Roles(String rname) {super();this.rname = rname;}public int getRid() {return rid;}public void setRid(int rid) {this.rid = rid;}public String getRname() {return rname;}public void setRname(String rname) {this.rname = rname;}}

Users.hbm.xml

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:41:45 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.Users" table="USERS">        <id name="uid" type="int">            <column name="UID" />            <generator class="native" />        </id>        <property name="uname" type="java.lang.String">            <column name="UNAME" />        </property>                <set name="roles" table="u_r" cascade="save-update">        <key column="uid"></key>        <many-to-many class="com.zking.entity.Roles" column="rid"></many-to-many>        </set>                    </class></hibernate-mapping>

Roles.hbm.xml

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN""http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><!-- Generated 2017-8-22 15:41:45 by Hibernate Tools 3.5.0.Final --><hibernate-mapping>    <class name="com.zking.entity.Roles" table="ROLES">        <id name="rid" type="int">            <column name="RID" />            <generator class="native" />        </id>        <property name="rname" type="java.lang.String">            <column name="RNAME" />        </property>                <set name="users" table="u_r">        <key column="rid"></key>        <many-to-many class="com.zking.entity.Users" column="uid"></many-to-many>        </set>            </class></hibernate-mapping>

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"><hibernate-configuration>    <session-factory>        <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>        <property name="hibernate.connection.password">password</property>        <property name="hibernate.connection.url">jdbc:mysql://localhost:3306/test</property>        <property name="hibernate.connection.username">root</property>              <property name="show_sql">true</property><property name="format_sql">true</property>        <mapping resource="com/zking/entity/Users.hbm.xml"/>             <mapping resource="com/zking/entity/Roles.hbm.xml"/>         </session-factory></hibernate-configuration>

package com.zking.test;import org.hibernate.Session;import org.hibernate.SessionFactory;import org.hibernate.Transaction;import org.hibernate.cfg.Configuration;import org.junit.After;import org.junit.Before;import org.junit.Test;import com.zking.entity.Card;import com.zking.entity.City;import com.zking.entity.Province;import com.zking.entity.Roles;import com.zking.entity.User;import com.zking.entity.Users;public class TestManyToMany {private SessionFactory sessionFactory;private Session session;private Transaction transaction;@Beforepublic void before(){Configuration configuration=new Configuration().configure();sessionFactory = configuration.buildSessionFactory();session = sessionFactory.openSession();transaction = session.beginTransaction();}@Afterpublic void after(){transaction.commit();session.close();sessionFactory.close();}@Testpublic void testAdd(){Users users1=new Users("辉辉");Users users2=new Users("静静");Roles roles1=new Roles("老公");Roles roles2=new Roles("老婆");Roles roles3=new Roles("儿子");Roles roles4=new Roles("孙子");users1.getRoles().add(roles1);users1.getRoles().add(roles3);users1.getRoles().add(roles4);users2.getRoles().add(roles2);users2.getRoles().add(roles4);//roles1.getUsers().add(users1);//roles2.getUsers().add(users2);//roles3.getUsers().add(users1);//roles4.getUsers().add(users1);//roles4.getUsers().add(users2);session.save(users1);session.save(users2);}}






原创粉丝点击