hibernate检索方式

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映射类型
java 复制代码
// 使用参数名字
String hql = "from User where id > :id";
List<User> users = session.createQuery(hql)
  .setInteger("id",2).list();
System.out.println(users);


// 使用参数位置
String hql = "from User where id > ?";
List<User> users = session.createQuery(hql)
  .setInteger(0,2).list();

分页查询

相关方法

  • setFirstResult(int) 从哪个位置开始检索
  • setMaxResults(int) 一次检索出多少条
java 复制代码
List<User> users = session.createQuery("from User")
                .setFirstResult(1)
                .setMaxResults(2).list();
System.out.println(users);

投影查询

只查部分字段,不查询全部数据

默认情况下hibernate查询返回的是一个个的Object[],如果查询部分字段的话,需要一个一个的去遍历赋值

java 复制代码
List<Object[]> result = session.createQuery("select id,name from User").list();
for(Object[] objs : result){
  System.out.println(Arrays.asList(objs));
}

当然上述方法太过于麻烦,可以使用构造器来实现

java 复制代码
//  注意:使用这种方式的话,要在类中有这样的构造器,当然不要忘了无参构造器必须有
List<User> result = session.createQuery("select new User(id,name) from User").list();
for(User user : result){
  System.out.println(user);
}

查询结果转换器

HQL检索方式和本地检索方式可以使用Transformers的aliasToBean方法来返回一个结果转换器

java 复制代码
this.getCurrentSession().createSQLQuery(sql)
        .addScalar("id", StandardBasicTypes.LONG)
        .addScalar("name",StandardBasicTypes.STRING)
        .setResultTransformer(Transformers.aliasToBean(User.class))
        .list();

Transformers.aliasToBean方法是返回一个AliasToBeanResultTransformer实例,所以也可以直接去实例化一个AliasToBeanResultTransformer

java 复制代码
public static ResultTransformer aliasToBean(Class target) {
   return new AliasToBeanResultTransformer(target);
}
java 复制代码
this.getCurrentSession().createSQLQuery(sql)
        .addScalar("id", StandardBasicTypes.LONG)
        .addScalar("name",StandardBasicTypes.STRING)
        .setResultTransformer(new AliasToBeanResultTransformer(User.class))
        .list();

QBC检索方式

使用Criteria查询

java 复制代码
Criteria criteria = session.createCriteria(User.class);
// 指定条件查询
criteria.add(Restrictions.eq("id",2));
User user = (User) criteria.uniqueResult();
System.out.println(user);

分页查询

java 复制代码
Criteria criteria = session.createCriteria(User.class);
criteria.setFirstResult(0);
criteria.setMaxResults(10);
List<User> users = criteria.list();

zhhll.icu/2020/框架/hib...

本文由mdnice多平台发布

相关推荐
桦说编程4 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen4 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研4 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国6 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~6 小时前
《设计模式》装饰模式
java·设计模式
A尘埃6 小时前
企业级Java项目和大模型结合场景(智能客服系统:电商、金融、政务、企业)
java·金融·政务·智能客服系统
青云交6 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市交通拥堵治理与出行效率提升中的应用(398)
java·大数据·flink·大数据可视化·拥堵预测·城市交通治理·实时热力图
CHEN5_027 小时前
【Java基础面试题】Java基础概念
java·开发语言