Hibernate中的HQL查询与缓存机制
HQL:完全面向对象查询
SQL的执行顺序:
1.From
2.Where 过滤基础数据
where与having的区别:1.顺序不同 2.where过滤基础数据 3. 过滤聚合函数
3.Group by
4.Select
5.Having
6.Order by
使用Hibernate查询时,使用hibernate的一个接口query
Hql是面向对象的查询语句,所以跟的是类名
Query query = session.createQuery(“select id,name,stu.cla.name from Student”);
List<Object[]> list = query.list();
For(Object[] obj : list){
........打印等
Obj[0] = id; Obj[1] = name; Obj[2] = stu.cla.name ;
}
查询后的数据存在一个Object数组里面
---------------------------------------------------------------------------------------------------------------------------------
list得到查询
List<List> list = = session.createQuery(“select new List(id,name,stu.cla.name) from Student”).list();
For(List list1 : list){
System.out.print(list1.get(0) + list1.get(1));
}
---------------------------------------------------------------------------------------------------------------------------------
Java对象查询 需要一个带参数的构造函数
创建一个中间类,包括所需要的属性等 new 对象:包名.类名
List<MyData> list = session.createQuery(“select new com.lovo.my.MyData(id,name,classname) from MyData”).list();
For(MyData data: list){
System.out.print(data.id + “ ” + data.name + “ ” + data.classname);
}
---------------------------------------------------------------------------------------------------------------------------------
Map得到查询
List<Map> list = = session.createQuery(“select new map(name as stuname,stu.cla.name as claname) from Student”).list();
For(Map map : list){
System.out.print(map.get(“stuname”) +” ” + map.get(“classname”));
}
---------------------------------------------------------------------------------------------------------------------------------
知道查询的结构是一个对象,获得一个结果集
Student stu = (Student)session.createQuery(“from Student where id=2”).uniqueResult();
(懒加载)有关联时: 当清除session后,会报懒加载错误
System.out.print(stu.getName()+” ” + stu.getCla().getName());
开启懒加载:1.配置中设置 lazy=”false” 2.在session关闭前,初始化 hibernate.initialize()
内连接:匹配才连接,不匹配不连接,会导致数据的丢失
Dto:数据持久化
单例模式:例如:private HibernateUtil(){} 不能new
Hibernate占位符:1.id= :id(命名参数) 2.id=?
Group by 投影有限制:1.group by之后的能投影 2.聚合函数
Round(需要取整的函数,保留几位小数)
IfNull(判断的数据,0);---如果数据为空,则用0代替
HQL中只能在Where / select 中使用子查询
用本地SQL/HQL语句:
Select name from t_student; Select id from t_student;
返回一列数据:用string接受 用Integer接受
session.createSQLQuery(Select * from t_student).addScalar(“name”).list();
在SQL语句中有标量,*则没有效果
session.createSQLQuery(Select * from t_student).addEnitity(Student.class).list();
把查询到的所有数据存储到Student对象中
Hibernate就是对JDBC的封装 :对数据库访问效率的降低和性能的下降(针对这个生成了缓存 ---- 内存中) 位于数据库和数据库访问层中
一级缓存:Session 缓存
Session.clear();-----清除session,缓存中的所有数据全部清除
lazy(懒加载)有懒加载:
1.需要什么数据则发送什么SQL语句
2.关闭懒加载:把所有的关联表全部用一条SQL语句连接,对象过多保存在内存中
3.关闭session时,懒加载也关闭
4.默认懒加载开启
抓取策略:
Session关闭后,立即抓取数据-----把所有的数据抓取到数据库中
From Student stu left join fetch stu,myclass where stu.id = 1;
二级缓存:用第三方jar包 sessionFactory级别
在hibernate配置下:
<!--查询缓存-->
<property name="cache.use_query_cache">true</property>
<!--开启二级缓存-->
<property name="cache.use_second_level_cache">true</property>
<!--配置echche的实现类-->
<property name="cache.region.factory_class">
org.hibernate.cache.EhCacheRegionFactory
</property>
Hibernate悲观和乐观锁:控制数据在操作时,不会被外界所破坏
悲观锁:锁表的状态 setLockMode(对象,LockMode.UPGPADE) 依赖数据库的锁表机制,t提交后才释放
乐观锁:主要采用版本的形式
配置:
1.创建类时,添加一个属性version int
2.Version必须配置在id的后面 <version name=”version” column=”version”></version>
Gson gson = new Gson();
String list = gson.toJson();
打成jar包:
1.file--export
2.输入jar --- jarfile
3.选择想要打的jar包 写入jar包名称 选择保存路径
Hibernate中的HQL查询与缓存机制的更多相关文章
- Hibernate中关于HQL查询返回List<Object>数据的结果集问题
---恢复内容开始--- 开发中遇到的一个小问题,使用Hibernate中的HQL查询时,使用query.list()查询出来的是一个List<Object>结果集 原来代码: publi ...
- 分享知识-快乐自己:Hibernate 中Criteria Query查询详解
1):Hibernate 中Criteria Query查询详解 当查询数据时,人们往往需要设置查询条件.在SQL或HQL语句中,查询条件常常放在where子句中. 此外,Hibernate还支持Cr ...
- Hibernate中的HQL语言
一.HQL语言简介 HQL全称是Hibernate Query Language,它提供了是十分强大的功能,它是针对持久化对象,直接取得对象,而不进行update,delete和insert等操作.而 ...
- Hibernate-ORM:15.Hibernate中的Criteria查询
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客讲师Hibernate中的Criteria查询! 一,Criteria简介: 刚接触Hibernate ...
- Hibernate-ORM:13.Hibernate中的连接查询
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客将会解释Hibernate中的连接查询(各种join) 一,目录 1.内链接 1.1显式内连接(inn ...
- Hibernate-ORM:08.Hibernate中的投影查询
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客将叙述hibernate中的投影查询 一,目录: 1.解释什么是投影查询 2.返回Object单个对象 ...
- 关于RecyclerView中Viewholder和View的缓存机制的探究
关于RecyclerView中Viewholder和View的缓存机制的探究 http://www.cnblogs.com/littlepanpc/p/4241575.html
- WCF技术剖析之八:ClientBase<T>中对ChannelFactory<T>的缓存机制
原文:WCF技术剖析之八:ClientBase<T>中对ChannelFactory<T>的缓存机制 和传统的分布式远程调用一样,WCF的服务调用借助于服务代理(Service ...
- Hibernate中的条件查询完成类
Hibernate中的条件查询有以下三个类完成: 1.Criteria:代表一次查询 2.Criterion:代表一个查询条件 3.Restrictions:产生查询条件的工具类
随机推荐
- MySQL_订单类型细分_20161222
#目前在做一个各城市日订单角度的对比分析,因此需要对订单类型进行一下规整.由于App上产品活动许多,查询了多个表,将订单类型规则进行了统一,优惠券和满减券不能同时使用,创建的这两个表都是以订单ID为k ...
- Hibernate和Struts2整合的增、删、改、查
1. 新建一个Web项目,准备好jar包和配置文件. 2. web.xml文件中添加过滤器 <?xml version="1.0" encoding="UTF-8& ...
- sql server之临时表
一.临时表介绍 临时表在运行被创建的,虽说它的名字叫做临时表,可是对它的操作和我们平时操控表的操作基本一样, 比如最简单增.删.改.查等等.但是,需要注意的是临时表的创建是有范围限制的. 二.临时表分 ...
- Network服务器
1.授权服务器与非授权服务器:大多数网游都是授权服务器,用户无法修改数据.
- UVALive - 4513 Stammering Aliens ——(hash+二分 || 后缀数组加二分)
题意:找一个出现了m次的最长子串,以及这时的最右的位置. hash的话代码还是比较好写的,,但是时间比SA多很多.. #include <stdio.h> #include <alg ...
- C#网络编程一:C#网络编程常用特性
特性一:委托 委托是C#语言中特有的概念,相当于C/C++中的函数指针,与C/C++中函数指针的不同之处是:委托是面向对象的.类型安全的和保险的,是引用类型.因此,对委托的使用要 "先定义. ...
- FP 某段SQL语句执行时间超过1个小时,并报错:ORA-01652: 无法通过 128 (在表空间 TEMPSTG 中) 扩展
一.出现如下两个错误:1.某一段SQL语句执行时间超过1个小时:2.一个小时后,提示如下错误:ORA-01652: 无法通过 128 (在表空间 TEMPSTG 中) 扩展 temp 段ORA-065 ...
- 关于$.fn.*的使用
这个案例是我封装了一个树形插件,也是别人写好的,但是对于我来说调用起来不是很方便,就对他的初始化方法又进行了一次封装,总的来说显得比较麻烦,不过我是新手嘛 DEMO 封装一个jcTree的方法$.fn ...
- Java实现文件压缩与解压
Java实现ZIP的解压与压缩功能基本都是使用了Java的多肽和递归技术,可以对单个文件和任意级联文件夹进行压缩和解压,对于一些初学者来说是个很不错的实例.(转载自http://www.puiedu. ...
- VS工程里的文件都是啥?如何打包? 2015-03-04
打完补充:以下内容全部是我一家之言,只是愿意分享,内容如有不妥还请见谅. ====================================================== 刚才接收了一份代 ...