hibernate中常用的Hql语句总结

  1. // HQL: Hibernate Query Language.
  2. // 特点:
  3. // >> 1,与SQL相似,SQL中的语法基本上都可以直接使用。
  4. // >> 2,SQL查询的是表和表中的列;HQL查询的是对象与对象中的属性。
  5. // >> 3,HQL的关键字不区分大小写,类名与属性名是区分大小写的。
  6. // >> 4,SELECT可以省略.
  7. // 1,简单的查询,Employee为实体名而不是数据库中的表名(面向对象特性)
  8. hql = "FROM Employee";
  9. hql = "FROM Employee AS e"; // 使用别名
  10. hql = "FROM Employee e"; // 使用别名,as关键字可省略
  11. // 2,带上过滤条件的(可以使用别名):Where
  12. hql = "FROM Employee WHERE id<10";
  13. hql = "FROM Employee e WHERE e.id<10";
  14. hql = "FROM Employee e WHERE e.id<10 AND e.id>5";
  15. // 3,带上排序条件的:Order By
  16. hql = "FROM Employee e WHERE e.id<10 ORDER BY e.name";
  17. hql = "FROM Employee e WHERE e.id<10 ORDER BY e.name DESC";
  18. hql = "FROM Employee e WHERE e.id<10 ORDER BY e.name DESC, id ASC";
  19. // 4,指定select子句(不可以使用select *)
  20. hql = "SELECT e FROM Employee e"; // 相当于"FROM Employee e"
  21. hql = "SELECT e.name FROM Employee e"; // 只查询一个列,返回的集合的元素类型就是这个属性的类型
  22. hql = "SELECT e.id,e.name FROM Employee e"; // 查询多个列,返回的集合的元素类型是Object数组
  23. hql = "SELECT new Employee(e.id,e.name) FROM Employee e"; // 可以使用new语法,指定把查询出的部分属性封装到对象中
  24. // 5,执行查询,获得结果(list、uniqueResult、分页 )
  25. Query query = session.createQuery("FROM Employee e WHERE id<3");
  26. query.setFirstResult(0);
  27. query.setMaxResults(10); // 等同于 limit 0,10
  28. //两种查询结果list、uniqueResult
  29. // List list = query.list(); // 查询的结果是一个List集合
  30. // Employee employee = (Employee) query.uniqueResult();// 查询的结果是唯一的一个结果,当结果有多个,就会抛异常
  31. // 6,方法链
  32. List list = session.createQuery(//
  33. "FROM Employee e")//
  34. .setFirstResult(0)//
  35. .setMaxResults(10)//
  36. .list();
  37. // 7,聚集函数:count(), max(), min(), avg(), sum()
  38. hql = "SELECT COUNT(*) FROM Employee"; // 返回的结果是Long型的
  39. hql = "SELECT min(id) FROM Employee"; // 返回的结果是id属性的类型
  40. //8,分组: Group By ... Having
  41. hql = "SELECT e.name,COUNT(e.id) FROM Employee e GROUP BY e.name";
  42. hql = "SELECT e.name,COUNT(e.id) FROM Employee e GROUP BY e.name HAVING count(e.id)>1";
  43. hql = "SELECT e.name,COUNT(e.id) FROM Employee e WHERE id<9 GROUP BY e.name HAVING count(e.id)>1";
  44. hql = "SELECT e.name,COUNT(e.id) " + //
  45. "FROM Employee e " + //
  46. "WHERE id<9 " + //
  47. "GROUP BY e.name " + //
  48. "HAVING count(e.id)>1 " + //
  49. "ORDER BY count(e.id) ASC";
  50. hql = "SELECT e.name,COUNT(e.id) AS c " + //
  51. "FROM Employee e " + //
  52. "WHERE id<9 " + //
  53. "GROUP BY e.name " + //
  54. "HAVING count(e.id)>1 " + // 在having子句中不能使用列别名
  55. "ORDER BY c ASC"; // 在orderby子句中可以使用列别名
  56. // 9,连接查询 / HQL是面向对象的查询
  57. //>> 内连接(inner关键字可以省略)
  58. hql = "SELECT e.id,e.name,d.name FROM Employee e JOIN e.department d";
  59. hql = "SELECT e.id,e.name,d.name FROM Employee e INNER JOIN e.department d";
  60. //>> 左外连接(outer关键字可以省略)
  61. hql = "SELECT e.id,e.name,d.name FROM Employee e LEFT OUTER JOIN e.department d";
  62. //>> 右外连接(outer关键字可以省略)
  63. hql = "SELECT e.id,e.name,d.name FROM Employee e RIGHT JOIN e.department d";
  64. //可以使用更方便的方法
  65. hql = "SELECT e.id,e.name,e.department.name FROM Employee e";
  66. // 10,查询时使用参数
  67. // >> 方式一:使用‘?‘占位
  68. hql = "FROM Employee e WHERE id BETWEEN ? AND ?";
  69. List list2 = session.createQuery(hql)//
  70. .setParameter(0, 5)// 设置参数,第1个参数的索引为0。
  71. .setParameter(1, 15)//
  72. .list();
  73. // >> 方式二:使用变量名
  74. hql = "FROM Employee e WHERE id BETWEEN :idMin AND :idMax";
  75. List list3 = session.createQuery(hql)//
  76. .setParameter("idMax", 15)//
  77. .setParameter("idMin", 5)//
  78. .list();
  79. // 当参数是集合时,一定要使用setParameterList()设置参数值
  80. hql = "FROM Employee e WHERE id IN (:ids)";
  81. List list4 = session.createQuery(hql)//
  82. .setParameterList("ids", new Object[] { 1, 2, 3, 5, 8, 100 })//
  83. .list();
  84. // 11,update与delete,不会通知Session缓存
  85. // >> Update
  86. int result = session.createQuery(//
  87. "UPDATE Employee e SET e.name=? WHERE id>15")//
  88. .setParameter(0, "无名氏")//
  89. .executeUpdate(); // 返回int型的结果,表示影响了多少行。
  90. // >> Delete
  91. int result1 = session.createQuery(//
  92. "DELETE FROM Employee e WHERE id>15")//
  93. .executeUpdate(); // 返回int型的结果,表示影响了多少行。
时间: 2024-08-02 03:28:03

hibernate中常用的Hql语句总结的相关文章

Spring中常用的hql查询方法(getHibernateTemplate()) 【转】

一.find(String queryString); 示例:this.getHibernateTemplate().find("from bean.User"); 返回所有User对象 二.find(String queryString , Object value); 示例:this.getHibernateTemplate().find("from bean.User u where u.name=?", "test"); 或模糊查询:th

c#中常用的js语句

1.document.write(""); 输出语句 2.JS中的注释为// 3.传统的HTML文档顺序是:document->html->(head,body) 4.一个浏览器窗口中的DOM顺序是:window->(navigator,screen,history,location,document) 5.得到表单中元素的名称和值:document.getElementById("表单中元素的ID號").name(或value) 6.一个小写转大

工作中常用SQL 查询语句备忘

--当A列大于B列时选择A列否则选择B列,当B列大于C列时选择B列否则选择C列.select (case when a>b then a else b end ), (case when b>c then b esle c end) from table_name --求和查询 create table #tmp(rq varchar(10), shengfu nchar(1)) insert into #tmp values('2005-05-09','胜') insert into #tm

SQL Server中常用的SQL语句(转):

SQL Server中常用的SQL语句 转自:http://www.cnblogs.com/rainman/archive/2013/05/04/3060428.html 1.概述 名词 笛卡尔积.主键.外键 数据完整性 实体完整性:主属性不能为空值,例如选课表中学号和课程号不能为空 参照完整性:表中的外键取值为空或参照表中的主键 用户定义完整性:取值范围或非空限制,例如:性别(男女),年龄(0-130) 表连接 自然连接:与等值连接(a.id=b.id)相比,连接后的表只有一列id,而不是两列

【SSH】Hibernate:常用的HQL语句

Hibernate query language 简称HQL,是实际开发中最长的hibernate查询封装模式. HQL提供了更加接近传统SQL语句的查询方法: <span style="font-family:Verdana;font-size:14px;">[select/update/delete-] [from-][where-][groupby-] [having -][order by-]</span> 实体查询: <span style=&q

项目中常用的SQL语句

摘要: 对于像我一样的菜鸟级别人物来说,接触的项目比较少,平常做的那些练习,包括三层中,一般也只能用到增删改查,当然这些增删改查语句是学数据库语句的入门,在百度上搜索一大堆,w3cschool中帮助文档也可以查阅. 这里是把平常用的增删改做一个小小总结,对一些小小项目也是比较适用的 ,当然,好记性不如烂笔头吗,这个时代纸质版的笔记感觉很欠缺,因为想要看的时候,你得找到那本书,而且要翻翻在哪里,感觉很不方便.并且电子版 的随便copy之类的都可以. 常用的sql语句(增删改查) 1.增加.插入语句

在hibernate3中如何利用HQL语句查询出对象中的部分数据并且返回该对象?

例如现在有一个Customer对象 public class Customer{ private Integer cid; private String cname; private Integer cage; } 现在说在hibernate中利用HQL查找出了cname一列值,然后将其封装成一个对象,问HQL要怎么写(投影操作)? 解决:1.在Customer实体类中添加一个带参的构造方法 public class Customer{ public Customer(){ super(); }

C#语言中常用的判断语句和循环语句

C#语言中,我们常用的判断语句和循环语句都有哪些呢? 1.if判断 代码格式:if(条件1){ 代码1 }else if(条件2){ 代码2               }else{ 代码N} 意义为:如果条件1成立,则执行代码1,否则判断条件2是否成立,如果成立,则执行代码2,如果以上条件都不成立,执行代码N. 注意:else部分可以省略,省略之后,意义变为"如果以上条件不成立,判断结束":else if 部分可以重复任意次数(一个不写,意义变为如果条件1成立执行代码1,否则执行代码

在Hibernate中使用原生SQL语句

使用原生SQL查询必须注意:程序必须选出所有的数据列才可被转换成持久化实体.假设实体在映射时有一个<many-to-one../>的关联指向另外一个实体,则SQL查询中必须返回该<many-to-one../>映射的外键列,否则将导致抛出"column not found"异常.最简单的做法是,在SQL字符串中使用星(*)来表示返回所有列.    在原生SQL语句中一样支持使用参数,这些参数即可使用问号参数(?),也可使用名字参数. 示例1:名字参数public