如果您无法下载资料,请参考说明:
1、部分资料下载需要金币,请确保您的账户上有足够的金币
2、已购买过的文档,再次下载不重复扣费
3、资料包下载后请先用软件解压,在使用对应软件打开
Hibernate常见面试题集1.在数据库中条件查询速度很慢的时候,如何优化?1.建索引2.减少表之间的关联3.优化sql,尽量让sql很快定位数据,不要让sql做全表查询,应该走索引,把数据量大的表排在前面4.简化查询字段,没用的字段不要,已经对返回结果的控制,尽量返回少量数据2.在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题?解决方案一,按照Object[]数据取出数据,然后自己组bean解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1filed1,type2field2),然后在hql里面就可以直接生成这个bean了。具体怎么用请看相关文档,我说的不是很清楚。3、HYPERLINK"http://www.mianwww.com/html/2009/08/3629.html"Hibernate对象的三种状态是什么?瞬时态(Transient)、持久态(Persistent)、脱管态(Detached)。处于持久态的对象也称为PO(PersistenceObject),瞬时对象和脱管对象也称为VO(ValueObject)。瞬时态由new命令开辟内存空间的java对象,eg.Personperson=newPerson(”amigo”,“女”);如果没有变量对该对象进行引用,它将被java虚拟机回收。瞬时对象在内存孤立存在,它是携带信息的载体,不和数据库的数据有任何关联关系,在Hibernate中,可通过session的save()或saveOrUpdate()方法将瞬时对象与数据库相关联,并将数据对应的插入数据库中,此时该瞬时对象转变成持久化对象。持久态处于该状态的对象在数据库中具有对应的记录,并拥有一个持久化标识。如果是用hibernate的delete()方法,对应的持久对象就变成瞬时对象,因数据库中的对应数据已被删除,该对象不再与数据库的记录关联。当一个session执行close()或clear()、evict()之后,持久对象变成脱管对象,此时持久对象会变成脱管对象,此时该对象虽然具有数据库识别值,但它已不在HIbernate持久层的管理之下。持久对象具有如下特点:1.和session实例关联;2.在数据库中有与之关联的记录。脱管态当与某持久对象关联的session被关闭后,该持久对象转变为脱管对象。当脱管对象被重新关联到session上时,并再次转变成持久对象。脱管对象拥有数据库的识别值,可通过update()、saveOrUpdate()等方法,转变成持久对象。脱管对象具有如下特点:1.本质上与瞬时对象相同,在没有任何变量引用它时,JVM会在适当的时候将它回收;2.比瞬时对象多了一个数据库记录标识值。4、HYPERLINK"http://www.mianwww.com/html/2009/02/3126.html"Hibernate中Query对象的使用Queryquery=session.createQuery(”selectcustomername,customeridfromCustomer”)Listl=query.list();For(inti=0;i<l.size();i++){Obejct[]object=(Object[])l.get(i);Object[0]object[1]}}分组:“selectcount(*),productnamefromProductgroupbyproductnameorderbyproductname”取值与属性一样配置的查询,在*.hbm.xml中<queryname=”sql”><![CDATA[fromProductwhereproductid=:productid]]></query>Queryquery=session.getNamedQuery(sql);联接1”fromCustomerascustomerjoinfetchcustomer.buySet”:将多的放到buySet属性中,得出的结是Customer有一个,Buy有多个联接2“fromCustomerascustomerjoincustomer.buySet”:得出的对象,customer与buy是1对1子查询:”fromCustomerascustomerwhere(selectcount(*)fromcustomer.buySet)>1″5。请你谈谈SSH整合SSH:Struts(表示层)+Spring(业务层)+Hibernate(持久层)Struts: