`
SIHAIloveYAN
  • 浏览: 112593 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类

hibernate教程--检索方式(hql,sql,QBC)

 
阅读更多

1.1Hibernate的检索方式

1.1.1Hibernate的检索方式:

检索方式:查询的方式:

导航对象图检索方式: 根据已经加载的对象导航到其他对象

* Customer customer = (Customer)session.get(Customer.class,1);

* customer.getOrders();// 获得到客户的订单


OID 检索方式: 按照对象的 OID 来检索对象

* get()/load();方法进行检索.

HQL 检索方式: 使用面向对象的 HQL 查询语言

* Query query = session.createQuery(“HQL”);


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

* Criteria criteria = session.createCriteria(Customer.class);

本地 SQL 检索方式: 使用本地数据库的 SQL 查询语句

* SQLQuery query = session.createSQLQuery(“SQL”);

1.1.2HQL:

HQL:Hibernate Query Language:

* 特点:

* 面向对象的查询:

* 支持方法链编程:

* 使用:

1.查询所有记录:

List<Customer> list = session.createQuery("from Customer").list();

for (Customer customer : list) {

System.out.println(customer);

}


2.查询使用别名:

// 使用别名

// 别名as可以省略

/*  List<Customer> list =

  session.createQuery("from Customer  c").list();

  System.out.println(list);*/

 

 

// 使用别名:带参数

/*List<Customer> list = session

.createQuery("from Customer as c where c.cname = ?")

.setString(0, "小沈").list();

System.out.println(list);*/

// 不支持 select * from Customer写法.可以写成 select 别名 from Customer as 别名;

List<Customer> list = session.createQuery("select c from Customer c").list();

System.out.println(list);

 


3.排序:

List<Customer> list = session.createQuery(

"from Customer c order by c.id desc").list();

for (Customer customer : list) {

System.out.println(customer);

}


4.分页查询:

Query query = session.createQuery("from Order");

query.setFirstResult(20);

query.setMaxResults(10);

List<Order> list = query.list();

for (Order order : list) {

System.out.println(order);

}


5.单个对象查询:

Customer customer = (Customer) session

.createQuery("from Customer where cname = ?")

.setString(0, "小明").uniqueResult();

System.out.println(customer);


6.参数绑定:

// 1.使用?号方式绑定

/*Query query = session.createQuery("from Customer where cname = ?");

query.setString(0, "小沈");

List<Customer> list = query.list();

System.out.println(list);*/

/*Query query = session.createQuery("from Customer where cname = ? and cid =?");

query.setString(0, "小沈");

query.setInteger(1,3);

List<Customer> list = query.list();

System.out.println(list);*/

// 2.使用名称的方式绑定

Query query = session.createQuery("from Customer where cname=:name and cid=:id");

query.setString("name", "小沈");

query.setInteger("id", 3);

List<Customer> list = query.list();

System.out.println(list);

 

// 3.绑定实体

List<Order> list = session

.createQuery("from Order o where o.customer = ?")

.setEntity(0, customer).list();

for (Order order : list) {

System.out.println(order);

}

 


7.投影操作:

// 查询客户的名称:

/*

 * List<Object> list = session.createQuery(

 * "select c.cname from Customer c").list(); System.out.println(list);

 */

 

/*

 * List<Object[]> list = session.createQuery(

 * "select c.cid,c.cname from Customer c").list(); for (Object[] objects

 * : list) { System.out.println(Arrays.toString(objects)); }

 */

 

List<Customer> list = session.createQuery(

"select new Customer(cname) from Customer").list();

System.out.println(list);


8.模糊查询:

Query query = session.createQuery("from Customer where cname like ?");

query.setParameter(0, "小%");

List<Customer> list = query.list();

System.out.println(list);

 


SQL多表查询:

* 连接:

* 交叉连接:

* select * from A,B;

* 内连接:查询的是两个表的交集!

* select * from A inner join B on A.字段 = B.字段;

* 隐式内连接:

* select * from A,B where A.字段 = B.字段;

* 外连接:

* 左外连接:

* select * from A left outer join B on A.字段 = B.字段;

* 右外连接:

* select * from A right outer join B on A.字段 = B.字段;

HQL多表的查询:

* 连接:

* 交叉连接:

* 内连接:

* 隐式内连接:

* 迫切内连接:

* 左外连接:

* 迫切左外连接:

* 右外连接:

* HQL的内连接和迫切内连接区别:

* 内连接查询 :将数据封装一个List<Object[]>中.

* 迫切内连接 :将数据封装一个List<Customer>中.但是迫切内连接,得到会有重复记录 ,需要使用distinct排重.

1.1.3QBC:

1.查询所有记录:

List<Customer> list = session.createCriteria(Customer.class).list();

for (Customer customer : list) {

System.out.println(customer);

}


2.排序:

List<Customer> list = session.createCriteria(Customer.class)

.addOrder(org.hibernate.criterion.Order.desc("id")).list();

for (Customer customer : list) {

System.out.println(customer);

}


3.分页:

Criteria criteria = session.createCriteria(Order.class);

criteria.setFirstResult(10);

criteria.setMaxResults(10);

List<Order> list = criteria.list();

for (Order order : list) {

System.out.println(order);

}


4.获取单个对象:

Customer customer = (Customer) session.createCriteria(Customer.class)

.add(Restrictions.eq("cname", "小明")).uniqueResult();

System.out.println(customer);


5.带参数的查询:

/*

 * List<Customer> list = session.createCriteria(Customer.class)

 * .add(Restrictions.eq("cname", "小明")).list();

 * System.out.println(list);

 */

 

List<Customer> list = session.createCriteria(Customer.class)

.add(Restrictions.eq("cname", "小明"))

.add(Restrictions.eq("cid", 2)).list();

System.out.println(list);

 


6.模糊查询:

Criteria criteria = session.createCriteria(Customer.class);

criteria.add(Restrictions.like("cname", "大%"));

List<Customer> list = criteria.list();

System.out.println(list);


1.1.4SQL:

1.SQL语句查询所有记录:

List<Object[]> list = session.createSQLQuery("select * from customer").list();

for (Object[] objects : list) {

System.out.println(Arrays.toString(objects));

}

 

List<Customer> list = session.createSQLQuery("select * from customer")

.addEntity(Customer.class).list();

for (Customer customer : list) {

System.out.println(customer);

}




分享到:
评论

相关推荐

    精通 Hibernate:Java 对象持久化技术详解(第2版).part2

     17.1.2 QBC检索方式  17.1.3 本地SQL检索方式  17.1.4 关于本章范例程序  17.1.5 使用别名  17.1.6 多态查询  17.1.7 对查询结果排序  17.1.8 分页查询  17.1.9 检索单个对象(uniqueResult()方法)  17.1...

    Hibernate 对象的状态检索

    本人在厦门邦初培训时候 使用的快速入门精简文档 Session缓存的作用 Session清理缓存的时间点 对象的临时状态、持久状态和游离状态 用session的update()方法使游离对象转变为持久化对象。...本地SQL检索方式

    hibernate基础 注解开发 检索

    hibernate的注解开发 注解开发关联映射 HQL、QBC、本地SQL检索数据

    Hibernate 课件及源代码

    内容涵盖安装 Hibernatetools 插件、Session 核心方法、持久化对象生命周期、对象关系映射(1-n、1-1、n-n、继承映射)、检索策略、检索方式(对象导航图、OID 检索、HQL、QBC、本地SQL)、Hibernate 一\二级缓存、...

    JSP开发中hibernate框架的常用检索方式总结

    总结hibernate框架的常用检索方式 1、hibernate框架的检索方式有以下几种: OID检索:根据唯一标识OID检索数据 对象导航检索:根据某个对象导航查询与该对象关联的对象数据 HQL检索:通过query接口对象查询 QBC...

    通俗易懂的Hibernate教程(含配套资料)

    内容涵盖安装 Hibernatetools 插件、Session 核心方法、持久化对象生命周期、对象关系映射(1-n、1-1、n-n、继承映射)、检索策略、检索方式(对象导航图、OID 检索、HQL、QBC、本地SQL)、Hibernate 一二级缓存、...

    hibernate总结

    2. 通过HQL/SQL 检索 hibernate query language (面向对象的查询语言) * a) 不再操纵表,它操纵的是持久化类的对象 b) 面向对象的 3. QBC ( query by criteria ) 更加面向对象 4. QBE ( query by Example ) 5....

    精通 Hibernate:Java 对象持久化技术详解(第2版).part4

     17.1.2 QBC检索方式  17.1.3 本地SQL检索方式  17.1.4 关于本章范例程序  17.1.5 使用别名  17.1.6 多态查询  17.1.7 对查询结果排序  17.1.8 分页查询  17.1.9 检索单个对象(uniqueResult()方法)  17.1...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part3

     17.1.2 QBC检索方式  17.1.3 本地SQL检索方式  17.1.4 关于本章范例程序  17.1.5 使用别名  17.1.6 多态查询  17.1.7 对查询结果排序  17.1.8 分页查询  17.1.9 检索单个对象(uniqueResult()方法)  17.1...

    精通 Hibernate:Java 对象持久化技术详解(第2版).part1.rar

     17.1.2 QBC检索方式  17.1.3 本地SQL检索方式  17.1.4 关于本章范例程序  17.1.5 使用别名  17.1.6 多态查询  17.1.7 对查询结果排序  17.1.8 分页查询  17.1.9 检索单个对象(uniqueResult()方法)  17.1...

    葵花宝典java面试

    1.Hibernate的检索方式 答:①导航对象图检索? ②OID检索? ③HQL检索? ④QBC检索? ⑤本地SQL检索 2. Forward与Global-Forward的区别 答:Forward是根据Action return的值找到对应的JSP页。当多个Action共同return...

    jdbc基础和参考

    1.hibernate提供的更面向对象的一种查询方式。 准备工作: 1.java中的POJO对象存在 2.数据库,表得存在 3.hibernate的配置文件(hibernate.cfg.xml)得存在 4.POJO.hbm.xml文件存在 5.hibernate的jar包以及数据库的...

    JAVA网站开发中的数据检索技术

    数据检索也可以称为数据查询,是对数据库中一个或多个数据表进行查询,并将查询结果反馈给用户。...在J2EE中,通常支持以下3中数据检索技术,即JDBC中的支持的SQL查询、Hibernate中支持的HQL和QBC查询。

    Java Web程序设计教程

    程序设计教程.pdf&gt;&gt;人民邮电出版社的教程哦,所以,好书,你懂的!! 第1章web应用开发简介 1 1.1何为web应用 1 1.1.1web的概念及发展 1 1.1.2web应用程序 2 1.2使用java开发web应用 3 1.2.1面向对象的编程语言...

    java 经典面试题 于网络分享

    5. Java语言中,方法的重写...8.以下哪些不是Hibernate的检索方式: A、导航对象图检索 B、OID检索 C、ORM检索 D、QBC检索 E、本地SQL检索 F、HQL检索 答案:C 9.以下代码定义了一个变量,如何输出这个变量的值?

    低清版 大型门户网站是这样炼成的.pdf

    5.4 qbc查询方式 314 5.4.1 基本查询 315 5.4.2 qbe查询 317 5.4.3 分页查询 318 5.4.4 复合查询 318 5.4.5 离线查询 319 5.5 本地sql查询 320 5.6 hibernate的批量处理 322 5.6.1 批量插入 322 5.6.2 批量...

Global site tag (gtag.js) - Google Analytics