package domain; import java.util.Date; public class IdCard { private int id; private Date usefulLise; private Person person; public int getId() { return id; } public void setId(int id) { this.id = id; } public Date getUsefulLise() { return usefulLise; } public void setUsefulLise(Date usefulLise) { this.usefulLise = usefulLise; } public Person getPerson() { return person; } public void setPerson(Person person) { this.person = person; } }
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="domain"> <class name="IdCard" table="`id_card`"> <id name="id" column="`id`"> <generator class="foreign"> <param name="property">person</param> </generator> </id> <property name="usefulLise" column="useful_life"/> <one-to-one name="person" constrained="true"></one-to-one> </class> </hibernate-mapping>
package domain; public class Person { private int id; private String name; private IdCard idCard; 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 IdCard getIdCard() { return idCard; } public void setIdCard(IdCard idCard) { this.idCard = idCard; } }
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping SYSTEM "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="domain"> <class name="Person" table="`person`"> <id name="id" column="`id`"> <generator class="native"> </generator> </id> <property name="name" unique="true"/> <one-to-one name="idCard"></one-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="domain/Person.hbm.xml"/> <mapping resource="domain/IdCard.hbm.xml"/> </session-factory> </hibernate-configuration>
package dao; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; public final class HibernateUtil { private static SessionFactory sessionFactory; private HibernateUtil(){} static{ Configuration cfg = new Configuration(); cfg.configure(); //cfg.setProperty(propertyName, value) sessionFactory = cfg.buildSessionFactory(); } public static SessionFactory getSessionFactory() { return sessionFactory; } public static Session getSession(){ return sessionFactory.openSession(); } }
package test; import java.util.Date; import org.hibernate.Session; import org.hibernate.Transaction; import dao.HibernateUtil; import domain.IdCard; import domain.Person; public class One2One { public static void main(String[] args) { Session session = null; Transaction tx = null; IdCard idCard = new IdCard(); Person person = new Person(); try { session = HibernateUtil.getSession(); idCard.setUsefulLise(new Date()); person.setName("admin"); person.setIdCard(idCard); idCard.setPerson(person); tx = session.beginTransaction(); //可以传id 然后用user.setId(id);再将user作为变量delete(user) session.save(person); session.save(idCard); tx.commit(); } catch (Exception e) { e.printStackTrace(); }finally{ if(session != null){ session.close(); } } query(1); } static void query(int id){ Session session = null; Transaction tx = null; try { session = HibernateUtil.getSession(); tx = session.beginTransaction(); //Person p = (Person) session.get(Person.class, id); //System.out.println(p.getIdCard().getUsefulLise()); IdCard idCard = (IdCard) session.get(IdCard.class, 1); System.out.println(idCard.getPerson().getName()); tx.commit(); } catch (Exception e) { e.printStackTrace(); }finally{ if(session != null){ session.close(); } } } }
表结构
person:
字段名 | 主键 | 类型 | 描述 |
id | pk | int | 人的编号 |
name | varchar(45) | 人的姓名 |
id_card:
字段名 | 主键 | 类型 | 描述 |
id | pk | int | 身份证编号(从人的编号读取) |
useful_life | Date | 有限期限 |