关于hibernate的查询

为什么建议hibernate查询全部字段

一般而言,要查询什么字段就查询什么字段,不要select * from表,但是在hibernate,我们其实可以不遵循这个规则,建议我们把所有属性都查询出来(可以封装成一个实体类),这样就省去了二次封装的过程,虽然浪费了一些资源,但利大于弊。当然如果一定要查询单个字段的话,那么只能从list中提取数据

hibernate的uniqueResult方法

如果你确定查询的是唯一的结果的话,那么建议使用uniqueResult方法,该结果返回一个对象(例如在验证用户登录中可以使用)

为什么说hibernate简化了sql的查询过程

看一个例子

在三表查询中 查询某选课号为3的学生的姓名,这里用到了三表查询,如果使用原生的sql语句要用到三级查询,而使用hql语句的话则是一句语句(用面对对象的思想)

select student.name,student.age from stutocourse where id=1;

关于hibernate的分页

session.createQuery("from Student").setFirstResult(i).setMaxResults(j).list();

其中setFirstResult()中的参数是从第几条开始,setMaxResults()中的参数是取几条。

查询后的返回对象的类型

如果查询的是一个字段的话list就存放的是一个object,如果查询的是多个字段的话那么存放的是object[];

猜你喜欢

转载自www.cnblogs.com/zhongyimeng/p/9751715.html