Hibernate多对一双向关联(xml配置)
来源:互联网 发布:分享动漫图片软件 编辑:程序博客网 时间:2024/05/11 17:12
转载地址:http://www.blogjava.net/sxyx2008/archive/2010/10/18/335461.html
Hibernate多对一双向关联(xml配置)
Department.java
package com.many2one.bean;
import java.util.Set;
public class Department {
private int id;
private String name;
private Set<Employee> sets;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<Employee> getSets() {
return sets;
}
public void setSets(Set<Employee> sets) {
this.sets = sets;
}
}
Employee.javaimport java.util.Set;
public class Department {
private int id;
private String name;
private Set<Employee> sets;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Set<Employee> getSets() {
return sets;
}
public void setSets(Set<Employee> sets) {
this.sets = sets;
}
}
package com.many2one.bean;
public class Employee {
private int id;
private String name;
private Department department;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Department getDepartment() {
return department;
}
public void setDepartment(Department department) {
this.department = department;
}
}
映射文件public class Employee {
private int id;
private String name;
private Department department;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Department getDepartment() {
return department;
}
public void setDepartment(Department department) {
this.department = department;
}
}
Department.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 package="com.many2one.bean">
<class name="Department" table="department" catalog="Hibernate_Many2One">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name" column="name"/>
</class>
</hibernate-mapping>
Employee.hbm.xml<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.many2one.bean">
<class name="Department" table="department" catalog="Hibernate_Many2One">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name" column="name"/>
</class>
</hibernate-mapping>
<?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 package="com.many2one.bean">
<class name="Employee" table="employee" catalog="Hibernate_Many2One">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name" column="name"/>
<many-to-one name="department" column="deptid" cascade="all" />
</class>
</hibernate-mapping>
导出的sql<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.many2one.bean">
<class name="Employee" table="employee" catalog="Hibernate_Many2One">
<id name="id" column="id">
<generator class="native"/>
</id>
<property name="name" column="name"/>
<many-to-one name="department" column="deptid" cascade="all" />
</class>
</hibernate-mapping>
create table Hibernate_Many2One.department (
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table Hibernate_Many2One.employee (
id integer not null auto_increment,
name varchar(255),
deptid integer,
primary key (id)
)
alter table Hibernate_Many2One.employee
add index FK4722E6AE3829E242 (deptid),
add constraint FK4722E6AE3829E242
foreign key (deptid)
references Hibernate_Many2One.department (id)
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table Hibernate_Many2One.employee (
id integer not null auto_increment,
name varchar(255),
deptid integer,
primary key (id)
)
alter table Hibernate_Many2One.employee
add index FK4722E6AE3829E242 (deptid),
add constraint FK4722E6AE3829E242
foreign key (deptid)
references Hibernate_Many2One.department (id)
测试代码
@Test
public void insert(){
Session session=HibernateSessionFactory.getSession();
Transaction transaction=session.beginTransaction();
try {
transaction.begin();
Department department=new Department();
department.setName("软件测试部");
Employee employee=new Employee();
employee.setName("张三");
employee.setDepartment(department);
session.save(employee);
transaction.commit();
} catch (HibernateException e) {
e.printStackTrace();
}
}
@Test
public void select(){
Session session=HibernateSessionFactory.getSession();
try {
Employee employee=(Employee) session.get(Employee.class, 1);
System.out.println(employee.getName());
System.out.println(employee.getDepartment().getName());
} catch (HibernateException e) {
e.printStackTrace();
}
}
public void insert(){
Session session=HibernateSessionFactory.getSession();
Transaction transaction=session.beginTransaction();
try {
transaction.begin();
Department department=new Department();
department.setName("软件测试部");
Employee employee=new Employee();
employee.setName("张三");
employee.setDepartment(department);
session.save(employee);
transaction.commit();
} catch (HibernateException e) {
e.printStackTrace();
}
}
@Test
public void select(){
Session session=HibernateSessionFactory.getSession();
try {
Employee employee=(Employee) session.get(Employee.class, 1);
System.out.println(employee.getName());
System.out.println(employee.getDepartment().getName());
} catch (HibernateException e) {
e.printStackTrace();
}
}
0 1
- Hibernate多对一双向关联(xml配置)
- Hibernate多对一双向关联(xml配置)
- Hibernate多对一双向关联(Annotation配置)
- hibernate一对多/多对一双向关联_Annotation
- hibernate一对多/多对一双向关联_XML
- Hibernate Annotation 一对多/多对一双向关联
- Hibernate关系映射(9)_多对一双向关联
- hibernate树形结构多对一双向关联
- Hibernate多对一双向关联(2)
- Hibernate多对一双表关联配置属性理解
- Hibernate关联关系总结一对多、多对一双向关联,多对多
- hibernate_0200_多对一双向关联
- 多对一双向关联映射测试
- Hibernate一对多单向,多对一单向,多对一双向关联
- Hibernate之关于一对多,多对一双向关联映射
- Hibernate关系映射(五)一对多、多对一双向关联@OneToMany @OneToMany Annotation方式
- hibernate(四)一对多单向、多对一双向、自身双向关联
- 8.4 Hibernate:一对多和多对一双向关联(bidirectional)
- POJ2377--Bad Cowtractors
- iOS 判断身份证号码
- log4c 学习笔记
- 怎么建立socket长连接???
- [LeetCode] Partition List
- Hibernate多对一双向关联(xml配置)
- ucontext簇函数学习
- shared_ptr的小文
- 解决由横向滑动引起的swiperefreshlayout刷新的冲突
- python的enumerate()
- 数据库事务隔离级别
- NSCache在IOS中的使用
- Android Studio的复制一行快捷键与Windows7屏幕旋转快捷键冲突
- HDU 1052 Tian Ji -- The Horse Racing