作为关联关系有多对一,有一对多。然后有一对一的关联。一对一可以主键之间的一对一也可以通过外键的一对一。
1对1的关系也是比较常见的一种关联。
看下面这个两个表
人表和身份证表。
一个人只有一张身份证,一个人只有一个id号。一个id号也只能对应一个人。人和是主表,身份证表示从属表。
下面写一个实例。对身份证表和人表的插入数据和查询。
1person类
package com.fish.testdao;
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;
}
}
2.idcard类
package com.fish.testdao;
import java.sql.Date;
public class IdCard {
private int id;
private Date useDate;
private Person person;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public Date getUseDate() {
return useDate;
}
public void setUseDate(Date useDate) {
this.useDate = useDate;
}
public Person getPerson() {
return person;
}
public void setPerson(Person person) {
this.person = person;
}
}
3.人xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/HibernateMapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.fish.testdao.Person">
<id name="id" type="integer">
</id>
<property name="name"></property>
<one-to-one name="idCard"></one-to-one>//在1对1你关系中idcard不会作为人表中的字段。
</class>
</hibernate-mapping>
4.idcard xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/HibernateMapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.fish.testdao.IdCard">
<id name="id" type="integer">
<generator class="foreign">/用这个属性说明,该表的id字段会从person类中的id中匹配过来,如何匹配的,就是通过下面property的值为person,因为你的one-to-one 是person
<param name="property">person</param>
</generator>
</id>
<property name="useDate"></property>
<one-to-one name="person"></one-to-one>
</class>
</hibernate-mapping>
下面写一个测试类:
package com.fish.domain;
import java.sql.Date;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.fish.testdao.IdCard;
import com.fish.testdao.Person;
public class Test3 {
//做一个session模板
public static Session getMySession() {
Configuration configuration = new Configuration();
configuration.configure("hibernate.cfg.xml");
SessionFactory factory = configuration.buildSessionFactory();
Session session = factory.openSession();
return session;
}
//对两个表的添加
public static void add() {
Session session = getMySession();
Transaction transaction = session.beginTransaction();
IdCard idCard = new IdCard();
idCard.setUseDate(new Date(0));
Person person = new Person();
idCard.setPerson(person);
person.setName("fish");
person.setIdCard(idCard);
person.setId(8);
transaction.begin();
session.save(person);
session.save(idCard);
transaction.commit();
session.close();
}
//对两个表的查询
public static void query() {
String hql = "fromPerson";
Session session = getMySession();
Query query = session.createQuery(hql);
List<Person> list= query.list();
for (Person i : list) {
System.out.println(i.getName() + "卡的日期为"
+ i.getIdCard().getUseDate());
}
session.close();
}
//主方法。
public static void main(String[] args) {
query();
}
}