hibernate 关系映射
这里是hibernate 关系 分别是 一对一,多对一,一对多。多对多
什么是一对一?
举个例子:
最好的证明 就是身份证,一个人只能有一张身份证,而身份证只能对应一个人,绝对不会有第二个人。这便是一对一
什么是多对一,一对多?
多个对应着一个
举个例子:
省份与城市
一个省份可以有多个城市:比如湖南 的省份城市可以有很多个 比如:长沙,永州,邵阳。 而一个城市只能对应一个省份 :长沙只能对应湖南。不能对应其他。
这便是一对多
什么是多对多?
这个歌关系呢 最经典的就是用户与角色的关系;
一个用户可以使用多个角色 , 一个角色也可以被多个用户使用
举个例子:
例如游戏,一个玩家可以有多个角色来使用,而那些个角色其他玩家也可以选择。
然后开始使用hibernate映射文件
这里我使用的工具是eclipse
我先新建了一个maven
首先第一步 在pom.xml里面 导入你所需要的依赖
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>Hibernate02</groupId>
<artifactId>Hibernate02</artifactId>
<packaging>war</packaging>
<version>0.0.1-SNAPSHOT</version>
<name>Testtest Maven Webapp</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.41</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11-beta-1</version>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.2.17.Final</version>
</dependency>
</dependencies>
<build>
<finalName>Hibernate02</finalName>
</build>
</project>
此时 点击保存 maven仓库就会自动去帮你下载你所需要的jar包
首先先开始新建实体类
category类别表
package com.zking.enetity;
import java.util.HashSet;
import java.util.Set;
public class Category {
//category类别表
private int category_id;//类别id 自动增长
private String category_name;//类别名
private Set<Product> products=new HashSet<Product>();
public Set<Product> getProducts() {
return products;
}
public void setProducts(Set<Product> products) {
this.products = products;
}
public Category() {
super();
// TODO Auto-generated constructor stub
}
public Category(String category_name) {
super();
this.category_name = category_name;
}
public int getCategory_id() {
return category_id;
}
public void setCategory_id(int category_id) {
this.category_id = category_id;
}
public String getCategory_name() {
return category_name;
}
public void setCategory_name(String category_name) {
this.category_name = category_name;
}
}
package com.zking.enetity;
import java.util.HashSet;
import java.util.Set;
public class Product {
//product产品表
private int product_no;//产品编号
private String product_name;//产品名
private String product_price;//产品价格
// private int category_id;//产品类别
private Category category;
private Set<Supply> Supply=new HashSet<Supply>();
public Set<Supply> getSupply() {
return Supply;
}
public void setSupply(Set<Supply> supply) {
Supply = supply;
}
public Category getCategory() {
return category;
}
public void setCategory(Category category) {
this.category = category;
}
public Product() {
super();
// TODO Auto-generated constructor stub
}
public Product(int product_no, String product_name, String product_price, int category_id) {
super();
this.product_no = product_no;
this.product_name = product_name;
this.product_price = product_price;
// this.category_id = category_id;
}
public Product(String product_name, String product_price) {
super();
this.product_name = product_name;
this.product_price = product_price;
}
public Product(String product_name) {
super();
this.product_name = product_name;
}
public int getProduct_no() {
return product_no;
}
public void setProduct_no(int product_no) {
this.product_no = product_no;
}
public String getProduct_name() {
return product_name;
}
public void setProduct_name(String product_name) {
this.product_name = product_name;
}
public String getProduct_price() {
return product_price;
}
public void setProduct_price(String product_price) {
this.product_price = product_price;
}
// public int getCategory_id() {
// return category_id;
// }
// public void setCategory_id(int category_id) {
// this.category_id = category_id;
// }
}
package com.zking.enetity;
import java.util.HashSet;
import java.util.Set;
public class Supply {
//supply供应商表
private int supply_no;//供应商编号
private String supply_name;//供应商名
private String supply_descn;//描述
private Set<Product> product=new HashSet<Product>();
public Set<Product> getProduct() {
return product;
}
public void setProduct(Set<Product> product) {
this.product = product;
}
public Supply() {
super();
// TODO Auto-generated constructor stub
}
public Supply(int supply_no, String supply_name, String supply_descn) {
super();
this.supply_no = supply_no;
this.supply_name = supply_name;
this.supply_descn = supply_descn;
}
public Supply(String supply_name, String supply_descn) {
super();
this.supply_name = supply_name;
this.supply_descn = supply_descn;
}
public int getSupply_no() {
return supply_no;
}
public void setSupply_no(int supply_no) {
this.supply_no = supply_no;
}
public String getSupply_name() {
return supply_name;
}
public void setSupply_name(String supply_name) {
this.supply_name = supply_name;
}
public String getSupply_descn() {
return supply_descn;
}
public void setSupply_descn(String supply_descn) {
this.supply_descn = supply_descn;
}
实体类以及完成 开始新建映射文件
在你的实体类包里面新建
点击之后 在里面的输入框内 输入你的实体类文件 点击OK
然后映射文件 就会自动生成了
再来设置对应的关系
这里给出一张结构图让大家更好的理解
给代码 来看看怎么样设置
Category.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 18:46:29 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="com.zking.enetity.Category" table="CATEGORY">
<id name="category_id" type="int">
<column name="CATEGORY_ID" />
<generator class="native" />
</id>
<property name="category_name" type="java.lang.String">
<column name="CATEGORY_NAME" />
</property>
<set name="products" table="Product" cascade="save-update">
<key column="category_id"></key>
<one-to-many class="com.zking.enetity.Product" />
</set>
</class>
</hibernate-mapping>
Product.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 18:42:59 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="com.zking.enetity.Product" table="PRODUCT">
<id name="product_no" type="int">
<column name="PRODUCT_NO" />
<generator class="native" />
</id>
<property name="product_name" type="java.lang.String">
<column name="PRODUCT_NAME" />
</property>
<property name="product_price" type="java.lang.String">
<column name="PRODUCT_PRICE" />
</property>
<many-to-one name="category" class="com.zking.enetity.Category" column="category_id"></many-to-one>
<set name="Supply" table="p_s" cascade="save-update">
<key column="product_no"></key>
<many-to-many class="com.zking.enetity.Supply" column="supply_no"></many-to-many>
</set>
</class>
</hibernate-mapping>
Supply.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 22:09:31 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
<class name="com.zking.enetity.Supply" table="SUPPLY">
<id name="supply_no" type="int">
<column name="SUPPLY_NO" />
<generator class="native" />
</id>
<property name="supply_name" type="java.lang.String">
<column name="SUPPLY_NAME" />
</property>
<property name="supply_descn" type="java.lang.String" >
<column name="SUPPLY_DESCN" />
</property>
<!-- <property name="setSupply_de" type="void" >
<column name="SETSUPPLY_DE" />
</property> -->
<set name="product" table="p_s" cascade="save-update">
<key column="supply_no"></key>
<many-to-many class="com.zking.enetity.Product" column="product_no"></many-to-many>
</set>
</class>
</hibernate-mapping>
这是我的多对多 一对多 配置
详解 大家可以参考结构图