getHibernateTemplate()方法
(2013-11-28 09:27:16)
开发环境:myeclipse 10 Oracle 11g
S2SH
在myeclipse的database数据库浏览器里,找到要做持久化类的表,将其进行hibernate reverse engineering
可以生成持久化类和相应的dao类
在dao类中几乎所有方法里用的都是getHibernateTemplate()
设有两个表:
Users表:id
username
password
person表:id
name
user_id(这个是外键,关联Users表的id列)
如果在myeclipse里反向生成持久化类的话,在Person类中将没有user_id这列,而是有一个Users类属性成员
用于表示与Users关联(多对一),同时在Users类中则相应有Set<Person>类的成员(一对多)。
Person类中
private Users users;//getter setter
这样,在PersonDAO类中的查询方法(以find开头的方法)取到的Person类实例或者List<Person>中,
例如public Person findById(Integer id){
……
return person;
}
这个方法是通过主键id来获取唯一的Person类对象结果
而获取的这个Person类对象中的Users类属性成员users只有一个属性id,其它的属性都是空
所以,想直接通过findById方法获取对应的Person对象,再获取此对象外键关联的Users对象的属性,只能得到users.id,其它都是null
一般来说,如果想获得完整的users,那就得通过UsersDAO的相关方法来获得
可是,很显然,如果在PersonDAO中引入UsersDAO是很不好的,那咋办捏?
还以findById方法为例,修改方法(假设持久化类都放在entity包下):
Person person=getHibernateTemplate().get("entity.Person",id);
//以下这两行是添加的
Users users=getHibernateTemplate().get("entity.Users",person.getUsers().getId());
person.setUsers(users);
return person;
这样就可以得到包含完整users属性的Person对象了
而且即使是后面的service层action层都不用在Person对应的类中调用Users相应类了
我估计会有更好的方法,暂时能想到的只是这个
在myeclipse的database数据库浏览器里,找到要做持久化类的表,将其进行hibernate reverse engineering
可以生成持久化类和相应的dao类
在dao类中几乎所有方法里用的都是getHibernateTemplate()
设有两个表:
Users表:id
person表:id
如果在myeclipse里反向生成持久化类的话,在Person类中将没有user_id这列,而是有一个Users类属性成员
用于表示与Users关联(多对一),同时在Users类中则相应有Set<Person>类的成员(一对多)。
Person类中
private Users users;//getter setter
这样,在PersonDAO类中的查询方法(以find开头的方法)取到的Person类实例或者List<Person>中,
例如public Person findById(Integer id){
}
这个方法是通过主键id来获取唯一的Person类对象结果
而获取的这个Person类对象中的Users类属性成员users只有一个属性id,其它的属性都是空
所以,想直接通过findById方法获取对应的Person对象,再获取此对象外键关联的Users对象的属性,只能得到users.id,其它都是null
一般来说,如果想获得完整的users,那就得通过UsersDAO的相关方法来获得
可是,很显然,如果在PersonDAO中引入UsersDAO是很不好的,那咋办捏?
还以findById方法为例,修改方法(假设持久化类都放在entity包下):
Person person=getHibernateTemplate().get("entity.Person",id);
//以下这两行是添加的
Users users=getHibernateTemplate().get("entity.Users",person.getUsers().getId());
person.setUsers(users);
return person;
这样就可以得到包含完整users属性的Person对象了
而且即使是后面的service层action层都不用在Person对应的类中调用Users相应类了
我估计会有更好的方法,暂时能想到的只是这个