Hibernate中的HQL
一、查询所有的时候
List<Company> list=session.createQuery("from Company as c order by c.cid desc").list();
不要写select *
注意:此处的Company不是表,而是映射过来的类。
二、取得单笔数据
Query<Company> query=session.createQuery("from Company as a order by a.price desc");
query.setMaxResults(1);//限定结果集就一笔数据
com=query.uniqueResult();//装载这一笔数据
方法为setMaxResults()和uniqueResult()方法。
三、带有参数的HQL语句
Query<Company> query=session.createQuery("from Company as a where a.name=:p1");
query.setParameter("p1","京东");
query.setMaxResults(1);
com=query.uniqueResult();
:p1,前面的冒号代表这是个变量。
四、取得多个字段,将取出的东西放在list中,前面代码已经出现,不在赘述
五、取得指定字段,使用投影
Query query=session.createQuery("select a.name,a.price form Company as a");
list=query.list();
Iterator it=list.iterator();
Object[] obj=null;//投影对象
while(it.hasNext()){
obj=((Object[])it.next());
System.out.printf("%s---%s\n",obj[0],obj[1]);
}
六、汇总函数的使用(也是用投影方法)
List list=null;
session = sessionFactory.openSession();
try{
Query query=session.createQuery("select " +
"count(c),sum(c.price),avg(c.price)," +
"min(c.price),max(c.price) " +
"from Company as c");
list=query.list();
Iterator it=list.iterator();
Object[] obj=null;//投影对象
while (it.hasNext()) {
obj=((Object[])it.next());
System.out.printf("%s---%s---%s---%s---%s\n",obj[0],obj[1],obj[2],obj[3],obj[4]);
}
七、比较
Query query=session.createQuery("from Emp as a where a.salary>:p1 and a.company.price>:p2");
query.setParameter("p1",2000.0);
query.setParameter("p2",100.0);
list=query.list();
for(Emp e :list){
System.out.printf("%s---%s---%s\n",e.getName(),e.getEmail(),e.getCompany().getName());
}
这里为了防止SQL注入,不写固定的比较值,而采用参数设置的方法。HQL中set只能用名称的方法来设置参数,不能使用index索引位置得方法。索引位置的方法只能用在SQL形式下。
如下:
Query query=session.createNativeQuery("select * form emp where salary>?");
query.setParameter(1,1200)
八、范围查询
try{
Query query=session.createQuery("from Emp as a " +
"where a.salary between 2000 and 13000 " +
"and a.company.name in('微软','百度')");
list=query.list();
for(Emp e :list){
System.out.printf("%s---%s---%s\n",e.getName(),e.getEmail(),e.getCompany().getName());
}
}
九、查询分页显示
公式:每页的记录条数(pagesize)、当前页号(pageNo)
query.setFirstResult((pageNo-1)*pageSize);
query.setMaxResult(pageSize);
try{
Query query=session.createQuery("from Emp as a");
int pageSize=2;//每页的记录条数
int pageNo=1;//当前页号,即第几页
//limit 1 ,2
query.setFirstResult((pageNo-1)*pageSize);//指定从哪一个对象开始检索 limit (pageNo-1)*pageSize ,pageSize
query.setMaxResults(pageSize);//指定一次最多检索出的对象数目
list=query.list();
for(Emp c :list){
System.out.printf("%s---%s---%s\n",c.getName(),c.getEmail(),c.getCompany().getName());
}
}
十、内连接(等效于一个外键连接)
try{
Query query=session.createQuery("from Emp as a inner join a.company as b ");
list=query.list();
for(MyReport c :list){
System.out.printf("%s-%s--%f\n",c.getName(),c.getCname(),c.getMoney());
}
}
十一、外连接(分为左外链接、右外连接)
左外连接:以Emp为主表,以company作为从表,如果emp有多于company表的数据同样打印出来,而company表多出来的不打印。
右外连接相反
try{
Query query=session.createQuery("from Emp as a left outer join a.company as b");
list=query.list();
Iterator it=list.iterator();
Object[] obj=null;//投影对象
while (it.hasNext()) {
obj=((Object[])it.next());
Company com=null;
if(obj[1]!=null){
com=(Company)obj[1];
}
Emp emp=(Emp)obj[0];
System.out.printf("%s---%s\n",emp.getName(),com!=null?com.getName():"");
}
}
十二、交叉连接(笛卡尔乘积)
try{
Query query=session.createQuery("from Company as a ,Emp as b ");
list=query.list();
Iterator it=list.iterator();
Object[] obj=null;//投影对象
while (it.hasNext()) {
obj=((Object[])it.next());
Emp emp=(Emp)obj[1];
Company com=(Company)obj[0];
System.out.printf("%s---%s\n",com.getName(),emp.getName());
}
}
十三、动态实例化查询:在查询过程中不仅可以查询到数据,还能将查询的内容构造一个类
try{
Query query=session.createQuery("select " +
"new com.weikun.po.MyReport(a.name, a.sex,b.name,b.price) " +
"from Emp as a inner join a.company as b ");
list=query.list();
for(MyReport c :list){
System.out.printf("%s-%s--%f\n",c.getName(),c.getCname(),c.getMoney());
}
}catch(Exception ex){
ex.printStackTrace();
}
Hibernate中的HQL的更多相关文章
- Hibernate中关于HQL查询返回List<Object>数据的结果集问题
---恢复内容开始--- 开发中遇到的一个小问题,使用Hibernate中的HQL查询时,使用query.list()查询出来的是一个List<Object>结果集 原来代码: publi ...
- 分享知识-快乐自己:Hibernate 中的 HQL 语句的实际应用
概要: Hibernate 支持三种查询方式: HQL查询.Criteria查询及原声 SQL (Native SQL)查询. HQL(Hibernate Query Language,Hiberna ...
- Hibernate中的HQL语言
一.HQL语言简介 HQL全称是Hibernate Query Language,它提供了是十分强大的功能,它是针对持久化对象,直接取得对象,而不进行update,delete和insert等操作.而 ...
- Hibernate中的HQL查询与缓存机制
HQL:完全面向对象查询 SQL的执行顺序: 1.From 2.Where 过滤基础数据 where与having的区别:1.顺序不同 2.where过滤基础数据 3. 过滤聚合函数 3.Group ...
- Hibernate 中update hql语句
今天在MySQL中用hibernate测试update语句发现以下问题: update语句竟然不去作用: 表机构如下: create table student(sid int primary key ...
- Hibernate中的HQL的基本常用小例子,单表查询与多表查询
<span style="font-size:24px;color:#3366ff;">本文章实现HQL的以下功能:</span> /** * hql语法: ...
- Hibernate中常用HQL
HQL是Hibernate自带的查询语言 HQL是一种面向对象的查询语言.SQL的操作对象是数据表和列等数据对象,而HQL的操作对象是类.实例.属性等. HQL的语法很像SQL的语法 以下举例均以学生 ...
- hibernate中使用HQL进行数据库查询
1.写的规则比较简单,我讲一下,如图Station这个不是数据库中的表,而是entity包中的类名Station,可以省略 select * 2.返回的类型自动转化为String类型,不用你自己再转化 ...
- Hibernate 中出现 users is not mapped 问题
Hibernate 中出现 users is not mapped 问题: 解答:HQL语句中表名应该是ORM映射的类名,所以应该改成: (如果是用注解生成实体类,那就是注解的那个类)String ...
随机推荐
- oracle实现查询每个部门的员工工资排在前三的员工的基本信息具体举例
--先删除原先存在的表: drop table emp; --创建表emp create table emp ( deptno number, ename varchar2(20), sal numb ...
- 创建cifs系统案例之“实现将Windows磁盘共享至Linux”
原创作品,出自 "深蓝的blog" 博客,欢迎转载,转载时请务必注明出处,否则追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlong ...
- oracle存储过程的使用
一. 使用for循环游标:遍历全部职位为经理的雇员 1. 定义游标(游标就是一个小集合) 2. 定义游标变量 3. 使用for循环游标 declare -- 定义游标c_job cursor c_jo ...
- hive1.2伪分布mysql数据库配置具体解释
hadoop2.6伪分布配置:http://blog.csdn.net/gamer_gyt/article/details/46793731 hive1.2 derby元数据库配置:http://b ...
- BroadcastReceiver类
java.lang.Object ↳ android.content.BroadcastReceiver 已知直接子类 AppWidgetProvider DeviceAdminReceiver ...
- java 基本数据类型及自己主动类型提升
基本数据类型:8种 1.整型: byte 1个字节 8位 -128到127 short 2个字节 16位 -2^15到(2^15)-1 int 4个字节 32 ...
- mysql如何查找表里的字段
在开发项目的时候有个功能需要查看数据库中有哪些表,以及每个表有哪些字段,在网上查看了一下,现在分享给大家. Oracle: 查询数据表(Tables)名称:select Table_Name, Tab ...
- js 预加载图片image()函数
创建一个Image对象:var a=new Image(); 定义Image对象的src: a.src=”xxx.gif”; 这样做就相当于给浏览器缓存了一张图片. 图像对象: 建立图像对 ...
- Flask上下文管理机制
前引 在了解flask上下文管理机制之前,先来一波必知必会的知识点. 面向对象双下方法 首先,先来聊一聊面向对象中的一些特殊的双下划线方法,比如__call__.__getattr__系列.__get ...
- 使用DWR实现JS调用服务端Java代码
DWR简介 DWR全称Direct Web Remoting,是一款非常优秀的远程过程调用(Remote Procedure Call)框架,通过浏览器提供的Ajax引擎实现在前端页面的JS代码中调用 ...