时间:2021-05-20
1、创建实体类(Customer.java、Orders.java)
复制代码 代码如下:
package wck.stu.vo.oneToMany_single;
import java.util.HashSet;
import java.util.Set;
public class Customer {
private String id = "";
private String cName = "";
private String bank = "";
private String phone = "";
private Set orders = new HashSet();
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getcName() {
return cName;
}
public void setcName(String cName) {
this.cName = cName;
}
public String getBank() {
return bank;
}
public void setBank(String bank) {
this.bank = bank;
}
public String getPhone() {
return phone;
}
public void setPhone(String phone) {
this.phone = phone;
}
public Set getOrders() {
return orders;
}
public void setOrders(Set orders) {
this.orders = orders;
}
}
Customer.java
复制代码 代码如下:
package wck.stu.vo.oneToMany_single;
public class Orders {
private String id = "";
private String orderNo = "";
private Double money = 0.0;
private Customer customer;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getOrderNo() {
return orderNo;
}
public void setOrderNo(String orderNo) {
this.orderNo = orderNo;
}
public Double getMoney() {
return money;
}
public void setMoney(Double money) {
this.money = money;
}
public Customer getCustomer() {
return customer;
}
public void setCustomer(Customer customer) {
this.customer = customer;
}
}
Orders.java
2、配置文件(Customer.hbm.xml、Orders.hbm.xml)
复制代码 代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="wck.stu.vo.oneToMany_single.Customer" table="CUSTOMER">
<id name="id" type="java.lang.String">
<column name="C_ID" length="32" not-null="true"></column>
<generator class="uuid.hex"></generator>
</id>
<property column="CNAME" name="cName" type="string" length="100"/>
<property column="BANK" name="bank" type="string" length="100"/>
<property column="PHONE" name="phone" type="string" length="20"/>
<!--一对多双向关联映射customer到orders,单的一方配置 -->
<set cascade="all" inverse="true" lazy="false" name="orders">
<key column="CUSTOMER_ID" />
<one-to-many class="wck.stu.vo.oneToMany_single.Orders" />
</set>
</class>
</hibernate-mapping>
Customer.hbm.xml
复制代码 代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="wck.stu.vo.oneToMany_single.Orders" table="ORDERS">
<id name="id" type="java.lang.String">
<column name="C_ID" length="32" not-null="true"></column>
<generator class="uuid.hex"></generator>
</id>
<property column="ORDERNO" name="orderNo" type="java.lang.String" length="17"/>
<property column="MONEY" name="money" type="java.lang.Double" />
<many-to-one name="customer" class="wck.stu.vo.oneToMany_single.Customer" column="CUSTOMER_ID" cascade="all" lazy="false" not-null="true"/>
</class>
</hibernate-mapping>
Orders.hbm.xml
3、测试代码
复制代码 代码如下:
public String saveCustomerInfo() {
Customer customer = new Customer();
customer.setcName("清华大学出版社");
customer.setBank("9559501012356789");
customer.setPhone("010-62772015");
Orders order = new Orders();
order.setOrderNo(new Long(System.currentTimeMillis()).toString());
order.setMoney(new Double(rnd.nextDouble()*10000));
order.setCustomer(customer);
customer.getOrders().add(order);
oneToManyDao.saveCustormerInfo(customer);
return customer.getId();
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
JSP开发之hibernate之单向多对一关联的实例一对多的基础上来测试单向多对一的关联hibernate多对一的关联关系定义:和单向一对多不同的是:一对多是在
作为一个ORM框架,hibernate肯定也需要满足我们实现表与表之间进行关联的需要。hibernate在关联方法的实现很简单。下面我们先来看看一对一的做法:不
一对多关联映射映射原理一对多关联映射和多对一关联映射的映射原理是一致的,都是在多的一端加入一个外键,指向一的一端。关联关系都是由多端维护,只是在写映射时发生了变
通常我们所说的关联关系包括下面三种:◇一对一关联:ONE_TO_ONE,包括HAS_ONE和BELONGS_TO◇一对多关联:ONE_TO_MANY,包括HAS
Hibernate多对多关联映射(many-to-many)在操作和性能方面都不太理想,所以多对多的映射使用较少,实际使用中最好转换成一对多的对象模型;Hibe