1. 首先是一个User2类:这个类用name和phone两个属性作为一个User2的识别标志
package CompoundKeys;
import java.io.Serializable;
//import org.apache.commons.lang.builder.EqualsBuilder;
//import org.apache.commons.lang.builder.HashCodeBuilder;
/*
当然可以將主鍵的資訊獨立為一個類別
*/
// 複合主鍵類的對應類別必須實作Serializable介面
public class User2 implements Serializable
{
private String name;//这里两个变量共同构成一个主键
private String phone;
private Integer age;
public User2() { }
public Integer getAge()
{
return age;
}
public void setAge(Integer age)
{
this.age = age;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
public String getPhone()
{
return phone;
}
public void setPhone(String phone)
{
this.phone = phone;
}
// 必須重新定義equals()與hashCode()
public boolean equals(Object obj)
{
if(obj == this) { return true;}
if(!(obj instanceof User2)){return false;}
User2 user = (User2) obj;
//这个需要单独的包
//return new EqualsBuilder()
// .append(this.name, user.getName())
// .append(this.phone, user.getPhone())
// .isEquals();
//
return this.name.equals(user.getName())&&this.phone.equals(user.getPhone());
}
public int hashCode()
{
//
//return new HashCodeBuilder()
// .append(this.name)
// .append(this.phone)
// .toHashCode();
//
return (name== null||phone==null) ? System.identityHashCode(this) : 29*name.hashCode()+phone.hashCode();
}
}
2。匹配方法:
<?xml version="1.0" encoding="GBK"?>
<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="CompoundKeys.User2" table="user">
<composite-id>
<key-property name="name" column="name" type="java.lang.String"/> <key-property name="phone" column="phone" type="java.lang.String"/>
</composite-id>
<property name="age" column="age" type="java.lang.Integer"/>
</class>
</hibernate-mapping>
3。Hibernate.cfg.xml: 注意这里我在前面例子的基础上加的
<?xml version='1.0' encoding='GBK'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!--Database connection settings -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost/yay</property>
<property name="connection.username">root</property>
<property name="connection.password">qwe123</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- Enable Hibernate's automatic session context management -->
<property name="current_session_context_class">thread</property>
<!-- Disable the second-level cache -->
<property name="cache.provider_class">org.hibernate.cache.NoCacheProvider</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">false</property>
<!-- Drop and re-create the database schema on startup -->
<!--property name="hbm2ddl.auto">create</property-->
<!--DBCP连接池设置,不用DBCP的时候,就不要这个配置部分-->
<property name="DBCP.min_size">5</property>
<property name="DBCP.max_size">20</property>
<property name="DBCP.timeout">1800</property>
<property name="DBCP.max_statements">50</property>
<!--这个配置mysql不支持:100个数据后就自动提交。这个可以不用配置-->
<property name="hibernate.jdbc.batch_size">100</property>
<!--这个指定事务管理用哪个,依賴於JDBC或JTA的事務管理功能,預設是使用JDBC事務管理-->
<property name="hibernate.transaction.factory_class">
org.hibernate.transaction.JDBCTransactionFactory
</property>
<mapping resource="events/Event.hbm.xml"/>
<mapping resource="events/Person.hbm.xml"/>
<mapping resource="MulToOne/Room.hbm.xml"/>
<mapping resource="MulToOne/User.hbm.xml"/>
<!--下面是复合主键-->
<mapping resource="CompoundKeys/User2.hbm.xml"/>
</session-factory>
</hibernate-configuration>
4。测试方法:
package CompoundKeys;
import org.hibernate.*;
import org.hibernate.cfg.*;
import java.util.*;
/*
1。说明的是,这里我只所以取名为User2而不是User类的目的是
当你的hibernate.cfg.xml中已经有了一个User类配置文件的时候,会发生混乱,
甚至会报告说配置文件错误。
*/
public class TestUser
{
public static void main(String[] args)
{
TestUser.Test();
}
public static void Test()
{
Session session =util.HibernateUtil.getSessionFactory().getCurrentSession();
Transaction tx = session.beginTransaction();
User2 user = new User2();
user.setName("bush");
user.setPhone("0970123456");
session.save(user);
user = (User2) session.load(User2.class, user);
System.out.println(user.getAge() + "/t" +
user.getName() + "/t" +
user.getPhone());
tx.commit();
util.HibernateUtil.getSessionFactory().close();
}
}