hibernate提供的5种检索数据方式
一、五种检索数据方式
1、OID检索,即使用session.get或session.load通过类及指定id查询数据,如Customer c=(Customer)session.get("Customer.class",1);
2、导航检索,即A类中含有另一个B类对象,获得A类后便可导航得到B对象数据
3、HQL检索,即使用hql语言得到数据,如session.createQuery("from Customer");
4、QBC检索,即使用QBC(Query By Criteria)API查询数据,如session.createCriteria(Customer.class);
5、本地SQL检索,即使用数据库SQL语句查询,如session.createSQLQuery("select * from customer");
HQL检索举例:
1、常见查询,查询所有客户
Query query=session.createQuery("from Customer");List<Customer> customerList=query.list();
2、也可以普通SQL语句查询,但是要指明查询字段
Query query=session.createQuery("select id,name from Customer");
query.list()返回的不是客户对象集合,而是List<Object[]>集合
3、查询id为1的客户,返回一个对象,可以使用query.uniqueResult();获取一个对象
Query query=session.createQuery("from Customer where id=1");Customer customer=(Customer)query.uniqueResult();
也可使用参数化方式传入查询条件值如hql语句为from Customer where id=? 则,传入参数query.setParameter(0,1);
如hql为from Customer where id=:id 则,传入参数query.setParameter("id",1);
4、多态查询可以返回检索类的子类数据,如果是PO类(含有hbm.xml映射文件的类)在from后面直接写类名,如果不是,则写类名全名(如java.lang.Object)
Query query=session.createQuery("from Customer");//检索出所有实体,如果有子类也会检索出
Query query=session.createQuery("from java.lang.Object");//检索出所有持久化对象
Query query=session.createQuery("from java.io.Serializable");//检索出所有实现Serializable接口的实例
query.list()就会把hibernate.cfg.xml中配置映射的所有相应类都取出来
本地SQL检索举例:(如果不用关联实体可以不做表和类映射)
1、普通SQL查询所有客户
SQLQuery sqlQuery=session.createSQLQuery("select * from customer");
List<Object[]> objsList=sqlQuery.list();
2、关联查询客户和订单
SQLQuery sqlQuery=session.createSQLQuery("select * from customer c left join orders o on c.id=o.cid");
List<Object[]> objsList=sqlQuery.list();
3、关联实体查询所有客户
SQLQuery sqlQuery=session.createSQLQuery("select * from customer");
List<Customer> customerList=sqlQuery.addEntity(Customer.class).list();
4、用表连接和关联实体方式查询客户张三所有订单
SQLQuery sqlQuery=session.createSQLQuery("select distinct o.* from customer c inner join orders o on c.id=o.cid where c.name=:name");
sqlQuery.setParameter("name","张三");
List<Order> orderList=sqlQuery.addEntity(Order.class).list();
补充:
1、投影查询
session.createQuery("select new Customer(id,name) from Customer").list();//需要有Customer(int id,String name)构造函数
session.createQuery("select new List(id,name) from Customer").list();//返回的是List集合套集合List<List<Object>>,如[[1,张三],[2,李四]]
session.createQuery("select new map(id,name) from Customer").list();
2、命名查询,在hbm.xml文件中配置HQL语句查询
如查询name为张三的客户
在hibernate-mapping节点下配置query,是在hibernate-mapping节点下,而不是class节点下
<query name="findCustomer">
<![CDATA[from Customer where name=?]]>
</query>
代码:Query query=session.getNamedQuery("findCustomer");query.setParameter(0,"张三");List list=query.list();
hibernate提供的5种检索数据方式的更多相关文章
- Java基础知识强化之IO流笔记35:InputStreamReader(Reader字符流的子类)2种read数据方式
1. InputStreamReader(Reader字符流的子类)2种read数据方式: InputStreamReader的read方法: int read():一次读取一个字符 int read ...
- Java基础知识强化之IO流笔记34:OutputStreamWriter(Writer字符流的子类)5种write数据方式
1. OutputStreamWriter (转换流) OutputStreamWriter 是字符流通向字节流的桥梁:可使用指定的 charset 将要写入流中的字符编码成字节. 同时OutputS ...
- JNDI提供了一种统一的方式,可以用在网络上查找和访问服务
JNDI提供了一种统一的方式,可以用在网络上查找和访问服务.通过指定一个资源名称,该名称对应于数据库或命名服务中的一个记录,同时返回数据库连接建立所必须的信息. JNDI主要有两部分组成:应用程序编程 ...
- android开发中的5种存储数据方式
数据存储在开发中是使用最频繁的,根据不同的情况选择不同的存储数据方式对于提高开发效率很有帮助.下面笔者在主要介绍Android平台中实现数据存储的5种方式. 1.使用SharedPreferences ...
- MySQL提供的几种检索行数据的优化方式
ICP(Index Condition Pushdown): 在MySQL5.6之前,存储引擎会通过遍历索引定位基表中 的行,然后返回给Server层,再去为这些数据进行WHERE后的条件过滤.MyS ...
- Dynamic CRM 2013学习笔记(十)客户端几种查询数据方式比较
我们经常要在客户端进行数据查询,下面分别比较常用的几种查询方式:XMLHttpRequest, SDK.JQuery, SDK.Rest. XMLHttpRequest是最基本的调用方式,JQuery ...
- HTML 5 Web 存储提供了几种存储数据的方法
localstorage存储对象分为两种: 1. sessionStorage: session即会话的意思,在这里的session是指用户浏览某个网站时,从进入网站到关闭网站这个时间段,sessio ...
- JavaScript 四种显示数据方式
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- NUI四种提交数据方式c
方式一: 1)前端页面 2)逻辑流参数设置 方式二: 1)前端页面 2)逻辑流参数设置 方式三: 1)前端页面 2)逻辑流参数设置 方式四: 1)前端页面 2)逻辑流参数设置
随机推荐
- Jquery easyui tree的使用
这个ui用的一切都是json数据.树也是如此! 后台需要返回与格式匹配的json数据才能正确加载树. 页面定义一个ui: <ul id="messageInfoAddTree" ...
- JS结合DOM事件的例子
// 这是初始文字 右边是一个测试文本框: 鼠标划过.点击.松开上面的文字都会有不同的效果,鼠标光标移到.离开文本框也会有不同的效果. 首先新建一个html文件 <!DOCTYPE html&g ...
- struct2cell
函数功能:把结构体转换为元胞数组. 语法格式: c = struct2cell(s) 如果s是m*n(m行n列)的二维的结构体数组,每个结构体含有p个域,则转换得到一个p*m*n的元胞数组c. 如果s ...
- [CareerCup] 10.6 Find Duplicate URLs 找重复的URL链接
10.6 You have 10 billion URLs. How do you detect the duplicate documents? In this case, assume that ...
- 我的权限系统设计实现MVC4 + WebAPI + EasyUI + Knockout(四)授权代码维护
一.前言 权限系统设计中,授权代码是用来控制数据访问权限的.授权代码说白了只是一树型结构的数据,没有什么其它的业务意义.那么这个页面的功能也就非常简单授权代码维护:新增.修改.删除授权代码数据. 二. ...
- grootJs 系统常用API接受
groot.absUrl(url) 把相对路径转换为绝对路径 groot.model 把vm对象转换为json 去掉系统生成的的属性groot.model groot.log 输出到控制台 兼容低版本 ...
- [vijos1264]神秘的咒语(LCIS)
描述身为拜月教的高级间谍,你的任务总是逼迫你出生入死.比如这一次,拜月教主就派你跟踪赵灵儿一行,潜入试炼窟底.据说试炼窟底藏着五行法术的最高法术:风神,雷神,雪妖,火神,山神的咒语.为了习得这些法术, ...
- [工具类]泛型集合转换为DataTable
写在前面 在实际项目中,用到了将集合转换为DataTable,就试着封装了一个方法,记录一下. 代码 using System; using System.Collections.Generic; u ...
- [C#]Attribute特性(2)——方法的特性及特性参数
上篇博文[C#]Attribute特性介绍了特性的定义,类的特性,字段的特性,这篇博文将介绍方法的特性及特性参数相关概念. 3.方法的特性 之所以将这部分单列出来进行讨论,是因为对方法的特性查询的反射 ...
- WCF入门(11)
前言 终于出太阳了. 可惜风太大,凉在阳台上的衣服全被吹到了地上,外加几双袜子被吹掉了,gone. 第11集 Difference between DataContract and MessageCo ...