`

Hibernate继承映射

阅读更多
继承映射分为三种情况
1.每个子类一张表
比如说有一个Person父类,有一个Student子类,一个Teacher子类。
假如我们操作的都是Student子类或者Teacher子类,就要为Teacher和Student各建立一张表。
Person类中有一些属性,被Student和Teacher继承下来。
而Student和Teacher有自己的属性,比如salaray和score.

类声明:

/**
 * Person作为父类 
 */
public class Person
{
	private String id;
	
	private String name;
}


/**
 * 继承父类Person 
 */
public class Student extends Person 
{
	 
	private String cardId;
}


public class Teacher	extends Person
{
	private int salary;
}






根据继承原则,私有属性不能被继承。但是在我们声明Person类的时候,由于里面的getter和setter都是public,因此当在Student.hbm.xml中使用代码提示的时候,就可以看到:



这是因为Hibernate获取我们的映射对象名称是根据方法名的。具体操作方法在之前反射的内容http://alleni123.iteye.com/admin/blogs/1965343中提到过。


Teacher.hbm.xml和Student.hbm.xml

<hibernate-mapping package="extend_mapping">
	<class name="Teacher" table="test_teacher">
	
 		<id name="id" column="id" type="string">
 			<generator class="uuid"></generator>
 		</id>
 		
 		<property name="name" column="name" type="string"/>
 		<property name="salary" column="salary" type="int"/>
 		
 	
	</class>

</hibernate-mapping>

<!--========================-->

<hibernate-mapping package="extend_mapping">
	<class name="Student" table="test_student">
	
 		<id name="id" column="id" type="string">
 			<generator class="uuid"></generator>
 		</id>
 		
 		
 		<property name="name" column="name" type="string"/>
 		<property name="cardId" column="cardId" type="string"></property>
 		
 		 
	</class>

</hibernate-mapping>



最后生成SQL语句:


Hibernate: create table test_student (id varchar2(255 char) not null, name varchar2(255 char), cardId varchar2(255 char), primary key (id))
Hibernate: create table test_teacher (id varchar2(255 char) not null, name varchar2(255 char), salary number(10,0), primary key (id))



插入

	Session session=HibernateUtil.openSession();
		
	 
		
		Student s=new Student();
		s.setCardId("111");
		s.setName("alleni");
		
		Teacher teacher=new Teacher();
		
		teacher.setSalary(1000);
		teacher.setName("eline");
		
		
		session.save(s);
		session.save(teacher);
		
		Transaction tx=session.beginTransaction();
		
		tx.commit();


生成数据:




查询

由于Student和Teacher表都有name, 我们会想查询两个表中的所有的name列内容。

因此这里要使用多态查询,如下:
Query query=session.createQuery("from Person");

'from Person'表示将继承了Person的类所映射的表全部查询出来。



注意:
List  l=query.list();
这里会报错,org.hibernate.hql.internal.ast.QuerySyntaxException: Person is not mapped [from Person]

原因是这里我们并没有定义Person的hbm文件。
解决方法是将Person的package名称加进查询语句中:
Query query=session.createQuery("from extend_mapping.Person");


完整代码如下:

		Session session=HibernateUtil.openSession();
		
	 
		//多态查询
		Query query=session.createQuery("from extend_mapping.Person");

 		
 		Iterator it=query.iterate();
 		
 		while(it.hasNext()){
 			Person p=(Person) it.next();
 			System.out.println(p.getClass().getName());
 			System.out.println(p.getName());
 			
 		}
 		
		
		
// 		List<Person>  l=query.list();
// 		
// 		System.out.println(l.size());
// 		
// 		for(Person p:l){
// 			System.out.println(p.getName());
// 		}


这里while循环语句输出如下:
Hibernate: select teacher0_.id as col_0_0_ from test_teacher teacher0_
Hibernate: select student0_.id as col_0_0_ from test_student student0_

extend_mapping.Teacher
eline
extend_mapping.Student
alleni

这里Hibernate分别向Person的两个子类中的对应的表发了SQL查询语句。
获取的内容也被Hibernate封装到了对应Class的类对象中。



  • 大小: 29.6 KB
  • 大小: 50.1 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics