ER:
名称 | 主键 | 类型 | 描述 |
id | pk | int | 员工编号 |
name | varcher(45) | 员工名称 | |
department_id | fk | int | 部门编号 |
名称 | 主键 | 类型 | 描述 |
id | pk | int | 部门编号 |
name | varchar(45) | 部门名称 |
package com.zchen.user.domain;
public class Department {
private int id;
private String name;
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;
}
}
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.zchen.user.domain"> <class name="Department" table="`department`"> <id name="id" column="`id`"> <generator class="native"> </generator> </id> <property name="name" unique="true"/> </class> </hibernate-mapping>
package com.zchen.user.domain;
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;
}
}
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.zchen.user.domain"> <class name="Employee" table="`employee`"> <id name="id" column="`id`"> <generator class="native"> </generator> </id> <property name="name"/> <many-to-one name="department" column="depart_id"></many-to-one> </class> </hibernate-mapping>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql:///user</property> <property name="connection.username">root</property> <property name="connection.password">mysqladmin</property> <property name="show_sql">true</property> <property name="hbm2ddl.auto">create</property> <mapping resource="com/zchen/user/domain/Department.hbm.xml"/> <mapping resource="com/zchen/user/domain/Employee.hbm.xml"/> </session-factory> </hibernate-configuration>
测试:
package test;
import org.hibernate.Session;
import org.hibernate.Transaction;
import com.zchen.user.dao.HibernateUtil;
import com.zchen.user.domain.Department;
import com.zchen.user.domain.Employee;
public class Mant2One {
public static void main(String[] args) {
add();
query(1);
}
public static Department add(){
Department depart = new Department();
Employee emp = new Employee();
Session session = null;
Transaction tx = null;
try {
depart.setName("事业部");
emp.setDepartment(depart);//对象模型 建立两个对象的关联
emp.setName("里斯");
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//session.save(depart);
//session.save(emp);
session.save(emp);
emp.setName("wangwu");
session.save(depart);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
}finally{
if(session != null){
session.close();
}
}
return depart;
}
static Employee query(int empId){
Session session = null;
Transaction tx = null;
Employee emp = null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
emp = (Employee)session.get(Employee.class, empId);
System.out.println("depart name"+emp.getDepartment().getName());
tx.commit();
} catch (Exception e) {
e.printStackTrace();
}finally{
if(session != null){
session.close();
}
}
return emp;
}
}