hibernate查询语句
很多同学在进行编程学习时缺乏系统学习的资料。本页面基于hibernate查询语句内容,从基础理论到综合实战,通过实用的知识类文章,标准的编程教程,丰富的视频课程,为您在hibernate查询语句相关知识领域提供全面立体的资料补充。同时还包含 h6、hack、hadoop 的知识内容,欢迎查阅!
hibernate查询语句相关知识
-
Hibernate Hql查询语句总结hql Hibernate中使用Query方法进行hql语句进行数据库查询 hql语法跟sql语法类似,学起来很容易 下面结合例子进行演示 案例说明 表一Commodity | Id | name | price | unit | category | description | seller | | 1 | 中式童装 | 120.00 | 套 | 童装 | 中式童装 | 4 | | 2 | 女士套装 | 200.00 | 套 | 女装 | 女士职业套装 | 1 | | 3 | 男士西服 | 200.00 | 套 | 男装 | 男士西服套装 | 1 | | 4 | 笔记本电脑 | 4000.00
-
Hibernate-HQL数据查询HQL简介 HQL是面向对象的查询语言,与SQL查询语言相比,虽然在语法上类似,都是运行时进行解析,但HQL并不像SQL那样操作的是数据表,列等数据库对象,HQL所操作的对象是类,对象,属性等。它也可以支持继承和多态等特征,在Hibernate 提供的各种检索方式中,HQL是使用最广泛的。 Query接口 Hibernate框架负责解析HQL语句,根据映射配置信息,把HQL查询语句解析成相应的SQL语句来执行数据库的查询操作。这一过程依赖的就是Query接口。Query的实例由Session的createQuery()方法创建
-
SQL基础查询语句SQL语句中,查询是使用最多的操作,SQL不仅能够查询表中的数据,还可以返回算术运算、表达式的结果等,接下来就一起了解一下基本的查询语句。基础SELECT语句查询指定字段语法格式:SELECT <字段名>,... FROM <表名>;在语句中可以指定多个字段,结果会根据指定的字段进行显示。例如,在users用户表中查询用户id、用户名、昵称、性别信息:SELECT user_id,user_name,nick_name,sex FROM users;查询全部字段查看表中的全部字段可以使用星号"*"表示,例如,以下语句查询users用户表中的所有数据:SELECT * FROM users;"*"代表所有字段,数据库在解析该语句时,会使用表中的字段名进行扩展,根据实际情况将"*"换成user_id、user_name、nick_name、sex、mobile、email等表的字段。设定别名使用AS关键字可以为列设定别名。SELECT user_id AS id,user_name AS
-
hql语句查询之时间段查询在网上查询好多时间段查询语句,但没解决我的问题,后来发现是我用错了类型。我以为时间段查询,那么数据库查询语句应该用date类型,但其实不然应使用String类型作为条件 如: "from 表名 o where o.createDate between '"+starttime+"' and '"+endtime+"'"; 或者用>=starttime and <=endtime也可以,这里如果你已经用Data类型接收了数据,那么转化为String类型就可以了 例如: String dateStr = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(starttime); String
hibernate查询语句相关课程
-
揭秘PHP模糊查询技术 在大数据时代,在繁杂的信息中,在PHP的开发过程中,通过什么技术能像“剪枝蔓,立主脑”一样快速准确地查找客户想要的信息?这技术就是PHP模糊查询技术,本课程就从本质上揭密PHP模糊查询技术。
讲师:HappyLiu 初级 24281人正在学习
hibernate查询语句相关教程
- 3. 原生 SQL 查询 Hibernate 支持原生 SQL 查询,对于熟悉并钟情于 SQL 语句的开发者来讲,是一个很大的福音。实例:String sql="select * from student";SQLQuery sqlQuery= session.createSQLQuery(sql);Hibernate 提供了一个与原生 SQL 有关的 SQLQuery 对象。SQLQuery 是 Query 的子类,可适应不同的原生 SQL 语句查询。
- 2.1 基础查询 为了更好地理解它们,来一个实例:查询姓名叫 “Hibernate” 的学生。Criteria criteria = session.createCriteria(Student.class);Criterion criterion = Restrictions.eq("stuName", "Hibernate");criteria.add(criterion);Student student = (Student) criteria.uniqueResult();System.out.println(student);Criteria 查询封装了关系型数据库的概念,所以,一定要注意,使用方法进行数据过滤时,都是属性进行比较。确认查询出来的数据只有一条记录时,可以使用 uniqueResult() 方法。条件查询的关键是了解 Restrictions,它所提供的很多类似于逻辑运算符的方法:Restrictions.eq(): 相当于 =;Restrictions.not(Exprission.eq()) : 相当于 <>;Restrictions.le(): 相当于 <=;Restrictions.gt(): 相当于 >;Restrictions.ge(): 相当于 >=;Restrictions.lt(): 相当于 <;Restrictions.isnull(): 相当于 is null;Restrictions.isNotNull(): 相当于 is not null ;Restrictions.like(): 相当于 like;Restrictions.and(): 相当于 and;Restrictions.conjunction(): 相当于 and;Restrictions.or(): 相当于 or;Restrictions.disjunction() : 相当于 or;Restrictions.not(): 相当于 not;Restrictions.in(): 相当于 in;Restrictions.not(Restrictions.in()): 相当于 not in;Restrictions.between(): 相当于 between x and y;Restrictions.not(Restrictions…between()) : 相当于 not between x and y。如上方法,几乎涵盖了所有 SQL 条件运算符,任意组合上面方法,没有查询不出来的结果。如查询学生编号是 1 或 2 或 4 的学生。使用 SQL,则是:select * from student where stuId in (1,2,4)使用 Criteria 查询,则如下所示:Criterion criterion = Restrictions.in("stuId",new Integer[] {1,2,4} );criteria.add(criterion);如查询学生编号大于 2 且班级编号为 1 的学生。使用 SQL:select * from student where stuId>2 and classRommId=1如果使用 Criteria 查询,则先构建两个约束对象:Criterion criterion = Restrictions.gt("stuId", 2);Criterion criterion1 = Restrictions.eqOrIsNull("classRoom.classRoomId", 1);再把这两个约束作为参数,构建一条联合约束:LogicalExpression logicalExpression = Restrictions.and(criterion, criterion1);criteria.add(logicalExpression);LogicalExpression API 用来表示一个逻辑表达式。是 Criterion 的子类。比较原生 SQL 和 Criteria 查询,会发现原生 SQL 语句要简单很多,使用 Criteria 查询需要掌握很多 API,而且代码量也比较大,这也可能是 Criteria 查询得不到普及的原因吧。但是,Hibernate 既然推出了这种查询方案,想必也有它的考虑。比如说,创建动态查询语句,这点原生 SQL 或 HQL 都没有 Criteria 好。还是那句话,存在就是合理的。如果,你对原生 SQL 有情怀,Criteria 查询中也是可以用的。criteria.add( Restrictions.sqlRestriction("stuId>2 and clasRoomId=1"));注意,不要在 Sql 片段中使用 where 关键字。既然是原生 SQL,所以语句中是字段概念,而不是属性概念。前面讲解 HQL 时,提到了分页查询。Criteria 一样可以实现分页查询,和 HQL 中分页方法一样:Criteria criteria = session.createCriteria(Student.class);criteria.setFirstResult(1);criteria.setMaxResults(5);List results = criteria.list();
- 2. Criteria 查询 什么是 Criteria 查询?Criteria 查询从字面翻译就是标准查询。所谓 标准查询,指的是 HIbernate 提供了纯正的 OOP API 查询方案。不像 HQL 还掺杂了一些 SQL 层面的内容。来一个查询需求:查询所有的学生。想必这学生会很生气,总是被搬来搬去的。上实例之前,先认识 Hibernate 兄弟会中的一名新成员:Criteria。在使用 Criteria 查询之前,必须先创建 Criteria 对象:Criteria cr = session.createCriteria(Student.class);List<Student> stus = cr.list();是不是很 OOP。使用 HQL 时,会有一种时空穿越的感觉 ,OOP 和 SQL 语法交替出现,很容易犯晕。使用 Criteria 进行查询时则不会。而且,Criteria 不是一个人在战斗,它也有属于自己的兄弟会,为开发者提供了更强有力的支持。先介绍一下它的几个兄弟,并且它们的作用已经从字面告诉了你。Criterion: 这位兄弟长得好生面熟,其实它就 Criteria 的单数存在形式;Oder: 提供排序功能;Restrictions: 限制、约束的意思,和 SQL 中的 where 关键字的作用是一样。所以,它提供了很多类似于运算符的方法,可以对查询数据进行过滤。Criteria 面子上很 OOP ,但是无论你怎么逃,都是在 SQL 的手掌心,也就是说 Criteria 查询最终还是会被 Hibernate 转译成 SQL 语句。只要是使用关系型数据库,SQL 就是逃不掉的宿命。只是直接、间接使用的区别。所以,Criteria 查询中总会找到 SQL 的影子。
- 2.2 HQL 高级查询 强参数查询使用 SQL 查询时,可以指定查询条件,这个地球人都知道。HQL 中同样能使用条件查询:from Student s where s.stuId> 2在 HQL 中,如果查询条件中的数据需要通过参数传递,则会有两种方案:匿名方案,已经司空见惯,对不对;from Student s where s.stuId> ?命名参数方案。from Student s where s.stuId> :id参数名前面一定要有一个冒号 :id。完整实例献上:String hql="from Student s where s.stuId> :id";Query query=session.createQuery(hql);query.setInteger("id", 2);List<Student> stus= query.list();for (Student student : stus) { ystem.out.println(student);}return null;可自行查看控制台上的输出结果。强命名参数和 ? 占位符作用是一样的,但是,强命名参数可减少指定实参时的出错率。分页查询分页查询是很实用的查询机制。使用原生 SQL 分页查询时,需要自己构建查询 SQL 语句,不同的数据库中的分页查询语句编写也有差异性。Hibernate 通过其提供的分页查询功能很好地避开了这些问题。分页查询之前,先搞清楚几个与查询有关的参数:pageSize: 每一页大小;pageNum: 页码。假如数据库中有 20 行数据,分页查询时指定 pageSize 为 5,则每 5 条数据为一个逻辑页,总共有 4 页。如果要查询第 3 页数据,即 pageNum=3。则需要跳过去的记录数为:(pageNum-1)*pageSize=(3-1)*5=10 ,也就是从第 11 条数据开始查询。现在直接上实例代码:String hql = "from Student s order by stuId" ;Query query = session.createQuery(hql);int pageNum=3;int pageSize=5;int passNum=(pageNum-1)*pageSize;query.setFirstResult(passNum);query.setMaxResults(pageSize);List<Student> stus = query.list();for (Student student : stus) { System.out.println(student.getStuName()); }return null;HIbernate 会从第 11 条记录开始,查询出 5 条记录。针对不同的数据库系统,Hibernate 会给出最佳的 SQL 分页方案。联合查询程序中所需要的数据可不一定在同一张表中,往往都是在多张表中。原生 SQL 通过多表连接或子查询方式解决这个问题。使用 HQL 一样能表达出多表连接的意图。可能你会问:前面的一对一、一对多、多对多映射关联关系后,不就已经能够查询出多张表中的数据吗。如下面表数据:在学生类中采用立即查询策略:@ManyToOne(targetEntity = ClassRoom.class, cascade = CascadeType.REMOVE,fetch=FetchType.EAGER)@JoinColumn(name = "classRoomId")public ClassRoom getClassRoom() { return classRoom;}查询所有学生:String hql = "from Student s";Query query = session.createQuery(hql);List<Student> stus = query.list();System.out.println("-----------------------------");for (Student student : stus) {System.out.println("学生姓名:"+student.getStuName());System.out.println("班级名称: "+student.getClassRoom().getClassRoomName()); }return null;不要怀疑,结果一定是会出现的。但是,可以看到控制台输出了很多 SQL 语句。那是因为,Hibernate 会先查询出所有学生,然后根据班级 ID 再进入班级表进行查询,这就是 Hibernate 查询过程的 1+N 问题。可改成下面的关联查询方式:String hql = "select s.stuName,c.classRoomName from Student s,ClassRoom c where s.classRoom=c";Query query = session.createQuery(hql);List<Object[]> stus = query.list();System.out.println("-----------------------------");for (Object[] student : stus) { System.out.println("学生姓名:"+student[0]); System.out.println("班级名称: "+student[1]); }return null;控制台输入结果:Hibernate: select student0_.stuName as col_0_0_, classroom1_.classRoomName as col_1_0_ from Student student0_ cross join ClassRoom classroom1_ where student0_.classRoomId=classroom1_.classRoomIdHibernate 仅构建了一条 SQL 语句,直接查询出来了所有数据,看得出来,其性能要大于 1+N 方案。HQL 比想象中要简单,比你预期的功能要强大。有了它,再也不怕查询不到我们需要的数据。
- 启动查询缓存 在 Hibernate 的主配置文件中添加如下配置信息:<property name="cache.use_query_cache">true</property>切记,使用查询缓存是一定要加入下面的代码:query.setCacheable(true);好吧,来一个实例,看看查询缓存的威力。Session session = sessionFactory.openSession();Transaction transaction = null;try { transaction = session.beginTransaction(); String hql = "from Student s"; Query query = session.createQuery(hql); query.setCacheable(true); System.out.println("------------------第一次查询-------------------"); List<Student> stus = query.list(); System.out.println(stus.size()); transaction.commit();} catch (Exception e) { transaction.rollback();} finally { session.close();}session = sessionFactory.openSession();transaction = null;try { transaction = session.beginTransaction(); String hql = "from Student s"; Query query = session.createQuery(hql); query.setCacheable(true); System.out.println("-----------------第二次查询--------------------"); List<Student> stus = query.list(); System.out.println(stus.size()); transaction.commit();} catch (Exception e) { transaction.rollback();} finally { session.close();}查看一下控制台上的输出结果:------------------第一次查询-------------------Hibernate: select student0_.stuId as stuId1_1_, student0_.classRoomId as classRoo5_1_, student0_.stuName as stuName2_1_, student0_.stuPassword as stuPassw3_1_, student0_.stuSex as stuSex4_1_ from Student student0_4-----------------第二次查询--------------------4结论很明显,第一次使用 list() 方法时,需要发送 SQL 语句,第二次时,就不再需要了,也就是说 list() 也是可以享受自己缓存的数据。但是必须启动查询缓存,且在代码中明明确确指示出来。
- 2. 一条查询语句是如何执行的 上一小节介绍了 MySQL 的逻辑架构组成,那么各模块之间是如何协同工作的呢?这里以一条最简单的查询语句为例子,我们一起来看看这条语句在 MySQL 内部是如何执行的。select id from a where id=1;
hibernate查询语句相关搜索
-
h1
h6
hack
hadoop
halt
hana
handler
hanging
hash
hashtable
haskell
hatch
hbase
hbuilder
hdfs
head
header
header php
headers
headerstyle