千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  应聘面试  >  Java面试题  > hibernate有几种查询方式?

hibernate有几种查询方式?

来源:千锋教育
发布人:qyf
时间: 2022-11-18 17:42:42 1668764562

  1. 导航对象图查询:根据已加载的对象,导航到其他对象 例如,对于已经加载的Customer对象,调用它的getOrders().iterator()方法就可以导航到所有关联的Order对象,假如在关联级别使用了延迟加载检索策略,那么首次执行此方法时,hibernate会从数据库中加载关联的Order对象,否则就从缓存中获得Order对象。

hibernate有几种查询方式

  2. OID方式:按照对象的OID来检索对象 Session的get()和load()方法提供了这种功能,如果在应用程序中先知道了OID,就可以使用这种方式检索对象。 get()和load()的用法完全一样,都需要两个参数,一个是持久化对象类名class,一个是行号OID,返回固定的某一行的数据,但是需要注意的是,当输入的OID不存在时,get()会返回一个空对象,load()则直接报错。

  3. HQL检索方式(hibernate query language) 使用面向对象的HQL查询语言,session的find()方法用于执行HQL查询语句。此外,hibernate还提供了query接口,它是hibernate提供的专门的HQL查询接口,能够执行各种复杂的HQL查询语句。

  它具备以下功能:

  - 在查询语句中设定各种查询条件;

  - 支持投影查询,即仅检索出对象的部分属性;

  - 支持分页查询;

  - 支持连接查询;

  - 支持分组查询;

  - 提供内置函数;

  - 能够调用用户自定义的SQL函数;

  - 支持子查询;

  - 支持动态绑定参数; 例如:Query query = session.createQuery(“from UserPo”); 获得一个query对象,注意参数字符串中不是一个SQL语句,from后面的是持久化对象名称; List list = query.list(); 就可以获取数据库中对应表的数据集合。

  4. QBC检索方式:Query By Criteria的API来检索对象,这种API封装了基于字符串形式的查询语句,提供了更加面向对象的接口。

  例如: Criteria criteria = session.createCriteria(UserPo.class); 创建一个Criteria对象,参数是所关联的持久化对象,criteria.add(Restrictions.ge("id",2));将查询条件加入对象中,后面的操作就和Query对象一样了。

  5. 利用原生SQL语句进行查询

tags:
声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT