hibernate的五种检索方式你都知道吗

hibernate的五种检索方式你都知道吗检索方式检索方式即为查询对象的方式hibernate提供了几种检索对象的方式导航对象图检索方式 :使用已加载的对象get获取关联对象OID检索方

大家好,欢迎来到IT知识分享网。

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映射类型
// 使用参数名字 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) 一次检索出多少条
List<User> users = session.createQuery("from User") .setFirstResult(1) .setMaxResults(2).list(); System.out.println(users); 

投影查询

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

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

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

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

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

QBC检索方式

使用Criteria查询

Criteria criteria = session.createCriteria(User.class); criteria.add(Restrictions.eq("id",2)); User user = (User) criteria.uniqueResult(); System.out.println(user);

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/53016.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信