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);}}
阅读全文
0 0
- Hibernate 之实体类之间的关系
- 框架学习之hibernate-02实体与实体之间的关系
- Hibernate学习小结之实体对象之间关系
- Hibernate实体类与数据表字段默认值之间的优先关系
- Hibernate之实体关系映射
- Hibernate之实体关系映射
- Hibernate3 实体之间的关系。
- 实体之间的级联关系
- CoreData 实体之间的关系
- Hibernate总结之二实体与表的映射关系
- Hibernate之jpa实体映射的三种继承关系
- Hibernate之jpa实体映射的三种继承关系
- SpringBoot中根据Hibernate的注解来关联实体之间的关系
- Snail—Hibernate之实体关系配置
- Hibernate 之实体表关系设计
- Hibernate学习-14:实体之间的关系及其配置,级联操作
- 解决Hibernate 实体类之间CRUD的代码冗余
- (9)实体之间的关系
- SqlSession(四)
- Single Number III问题及解法
- Java中的集合
- Volley源码分析
- Python Web入门:Django学习与实践之三(models)
- Hibernate 之实体类之间的关系
- 埃氏筛法
- 【转】几种常用的优化方法
- springMVC的请求参数乱码问题
- 合并排序的非递归实现(自底向上设计)
- HDU 6170 / 多校1010 Two strings (dp)
- scikit-learn数据预处理fit_transform()与transform()的区别(转)
- Linux--sed
- jQuery-JS常用表单验证&35个jQuery小技巧