hibernate检索方式
检索方式即为查询对象的方式
hibernate提供了几种检索对象的方式
- 导航对象图检索方式 :使用已加载的对象get获取关联对象
- OID检索方式 :使用OID来获取对象get()和load()方法
- HQL检索方式:使用面向对象的HQL(Hibernate Query Language)查询语言Query
- QBC检索方式:使用QBC(Query By Criteria)API来检索对象
- 本地SQL检索方式:使用本地数据库的SQL查询语句
HQL检索方式
使用Query.createQuery()方法创建Query对象
绑定参数
Hibernate的参数绑定机制依赖于JDBC中的PreparedStatement的预定义SQL语句,有两种形式
- 按参数名字绑定 命名参数以:开头
- 按参数位置绑定 用?来定义参数位置
相关方法
- setEntity() 把参数与一个持久化类绑定
- setParameter() 绑定任意类型的参数,该方法的第三个参数显示指定Hibernate映射类型
1 | // 使用参数名字 |
分页查询
相关方法
- setFirstResult(int) 从哪个位置开始检索
- setMaxResults(int) 一次检索出多少条
1 | List<User> users = session.createQuery("from User") |
投影查询
只查部分字段,不查询全部数据
默认情况下hibernate查询返回的是一个个的Object[],如果查询部分字段的话,需要一个一个的去遍历赋值
1 | List<Object[]> result = session.createQuery("select id,name from User").list(); |
当然上述方法太过于麻烦,可以使用构造器来实现
1 | // 注意:使用这种方式的话,要在类中有这样的构造器,当然不要忘了无参构造器必须有 |
查询结果转换器
HQL检索方式和本地检索方式可以使用Transformers的aliasToBean方法来返回一个结果转换器
1 | this.getCurrentSession().createSQLQuery(sql) |
Transformers.aliasToBean方法是返回一个AliasToBeanResultTransformer实例,所以也可以直接去实例化一个AliasToBeanResultTransformer
1 | public static ResultTransformer aliasToBean(Class target) { |
1 | this.getCurrentSession().createSQLQuery(sql) |
QBC检索方式
使用Criteria查询
1 | Criteria criteria = session.createCriteria(User.class); |
分页查询
1 | Criteria criteria = session.createCriteria(User.class); |