hibernate映射复合主键-1

联合主键的映射规则
1:类中的每个主键属性都对应到数据库中的每个主键列。

Hiberanate要求具有联合主键的实体类实现Serializable接口,并且重写hashCode和equals方法,重写这两个方法的原因在于hibernate要根据数据库的联合主键来判断某两行的记录是否一样的,如果一样那么就认为是同一个对象,如果不一样,那么就认为是不同的对象。这就反映到程序领域中就是根据hashCode和equals方法来判断某二个对象是否能够放到诸如Set这样的集合中。联合主键的实体类实现Serializable接口的原因在于使用get或者load方法的时候需要构建出改实体的对象,并将查询的依据(联合主键)设置进去,然后作为get或者load方法的第二个参数传递进去即可。

package model;

import java.io.Serializable;

public class Student implements Serializable {
	private String cardId;
	
	private String name;
	
	private int age;

	public String getCardId() {
		return cardId;
	}

	public void setCardId(String cardId) {
		this.cardId = cardId;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((cardId == null) ? 0 : cardId.hashCode());
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Student other = (Student) obj;
		if (cardId == null) {
			if (other.cardId != null)
				return false;
		} else if (!cardId.equals(other.cardId))
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}
	
	
}

<?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>
	<class name = "model.Student" table = "student" lazy="true">
		<composite-id>
			<key-property name="cardId" column = "cardId" type = "string"></key-property>
			<key-property name = "name" column = "name" type = "string"></key-property>
		</composite-id>
		<property name="age" column = "age" type = "integer"></property>
	</class>
</hibernate-mapping>


package model;

import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;

/**
 * 
 create table student (cardId varchar(255) not null, name varchar(255) not null, age integer, primary key (cardId, name))
 *
 */
public class Create {
	public static void main(String[] args) {
		SchemaExport export = new SchemaExport(new Configuration().configure());
		export.create(true, true);
	}
}
package model;

import org.hibernate.Session;
import org.hibernate.Transaction;

public class Test {
	public static void main(String[] args) {
		save();
	}
	static void save () {
		Session session = HibernateUtil.getSession();
		Transaction tx = null;
		try {
			tx = session.beginTransaction();
				Student student = new Student ();
				student.setAge(660000);
				student.setCardId("123");
				student.setName("张三");
				session.save(student);
			tx.commit();
		}catch (Exception ex) {
			ex.printStackTrace();
			if (null != tx) {
				tx.rollback();
			}
		}finally {
			HibernateUtil.close(session);
		}
	}
}
save():

Hibernate: insert into student (age, cardId, name) values (?, ?, ?)

2:将主键所对应的属性提取出一个类(称之为主键类),并且主键类需要实现Serializable接口,重写equals方法与hashcode方法。

package model;

import java.io.Serializable;

public class StudentPrimaryKey implements Serializable {
	private String cardId;
	
	private String name;

	public String getCardId() {
		return cardId;
	}

	public void setCardId(String cardId) {
		this.cardId = cardId;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + ((cardId == null) ? 0 : cardId.hashCode());
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		StudentPrimaryKey other = (StudentPrimaryKey) obj;
		if (cardId == null) {
			if (other.cardId != null)
				return false;
		} else if (!cardId.equals(other.cardId))
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}
	
}

package model;

import java.io.Serializable;

public class Student{
	private StudentPrimaryKey studentPrimaryKey;
	
	private int age;

	public StudentPrimaryKey getStudentPrimaryKey() {
		return studentPrimaryKey;
	}

	public void setStudentPrimaryKey(StudentPrimaryKey studentPrimaryKey) {
		this.studentPrimaryKey = studentPrimaryKey;
	}

	public int getAge() {
		return age;
	}

	public void setAge(int age) {
		this.age = age;
	}
	
}
package model;

import org.hibernate.Session;
import org.hibernate.Transaction;

public class Test {
	public static void main(String[] args) {
		//save();
		fetch();
	}
	static void save () {
		Session session = HibernateUtil.getSession();
		Transaction tx = null;
		try {
			tx = session.beginTransaction();
				Student student = new Student ();
				student.setAge(100);
				
				StudentPrimaryKey studentPrimaryKey = new StudentPrimaryKey();
				studentPrimaryKey.setCardId("123");
				studentPrimaryKey.setName("lisi");
				
				student.setStudentPrimaryKey(studentPrimaryKey);
				
				session.save(student);
			tx.commit();
		}catch (Exception ex) {
			ex.printStackTrace();
			if (null != tx) {
				tx.rollback();
			}
		}finally {
			HibernateUtil.close(session);
		}
	}
	
	static void fetch () 
	
	{
		Session session = HibernateUtil.getSession();
		Transaction tx = null;
		try {
			tx = session.beginTransaction();
				
				StudentPrimaryKey studentPrimaryKey = new StudentPrimaryKey();
				studentPrimaryKey.setCardId("123");
				studentPrimaryKey.setName("lisi");
				Student student = (Student)session.get(Student.class, studentPrimaryKey);
				System.out.println(student.getAge());
				session.save(student);
			tx.commit();
		}catch (Exception ex) {
			ex.printStackTrace();
			if (null != tx) {
				tx.rollback();
			}
		}finally {
			HibernateUtil.close(session);
		}
		
	}
}



package model;

import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;

/**
 * 
 create table student (cardId varchar(255) not null, name varchar(255) not null, age integer, primary key (cardId, name))

 */
public class Create {
	public static void main(String[] args) {
		SchemaExport export = new SchemaExport(new Configuration().configure());
		export.create(true, true);
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值