Java之旅hibernate(7)——数据加载get和load
2015-08-24 12:14
615 查看
通过上篇博客介绍的hibernate的三种状态,从而将我们的数据存入了数据库,下面我们来看看存到数据库的数据又该如何获取或者说是加载呢?
通常情况下我们采用两种方式进行加载,第一种是get,第二种是load,那么这两种方式又存在什么区别和联系呢?
![](http://img.blog.csdn.net/20150824120945988?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
加载时是持久化状态的对象,那么在commit的时候可以直接提交到数据库。代码:
![](http://img.blog.csdn.net/20150824120951125?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
Load的用法和get一样,只是两者的加载策略不一样,存在一个延迟加载。代码
![](http://img.blog.csdn.net/20150824120956327?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
调试查看会发现此时会生成一个代理类,因为没有实现接口,无法生成jdk代码,但是这里继承了第三方cglib生成了一个代理。
只有当用的时候才会执行相关的查询语句,支持延迟加载不同于get是立即加载,也就是支持lazy加载(在以后的文章会继续介绍)
如果查询的返回结果没有,也就是对象没有找到的时候,则会抛出异常。
通常情况下我们采用两种方式进行加载,第一种是get,第二种是load,那么这两种方式又存在什么区别和联系呢?
1. Get获取数据
Get只能根据主键取值,get加载上来的对象为持久对象,并且是马上发出查询。还有一个特点是如果查找不到相应的数据时会返回null值,而不会抛出异常。Get方法的相关的参数
Class就是需要查找的实体类,而id就是实体类的主键(序列化后的id)
Class是需要操作的实体类,获取到序列号为赋值类型的user实体数据,将关系类型转换为实体对象,代码:加载时是持久化状态的对象,那么在commit的时候可以直接提交到数据库。代码:
Session session = null; try { session = HibernateUtils.getSession(); session.beginTransaction(); //get加载上来的对象为持久对象 //执行get会马上发出查询语句 User user = (User)session.get(User.class, "402880812553589901255358e2b30001"); System.out.println(user.getName()); //Persistent状态 //Persistent状态的对象,当对象的属性发生改变的时候 //hibernate在清理缓存(脏数据检查)的时候,会和数据库同步 user.setName("赵柳"); session.getTransaction().commit(); }catch(Exception e) { e.printStackTrace(); session.getTransaction().rollback(); }finally { HibernateUtils.closeSession(session); }
返回结果
使用get方法时需要判断返回的结果是不是为空,为空则进行相关的处理。即使为空也就是null,是不会抛出异常。Session session = null; try { session = HibernateUtils.getSession(); session.beginTransaction(); //get方法加载数据,如果不存在返回null User user = (User)session.get(User.class, "54434343434343"); System.out.println(user.getName()); session.getTransaction().commit(); }catch(Exception e) { e.printStackTrace(); session.getTransaction().rollback(); }finally { HibernateUtils.closeSession(session); }
2. Load获取数据
Load方法的相关参数
Load的用法和get一样,只是两者的加载策略不一样,存在一个延迟加载。代码
Session session = null; try { session = HibernateUtils.getSession(); session.beginTransaction(); //不会马上发出查询语句,因为load支持lazy(延迟加载/懒加载) //什么叫lazy?只有真正使用这个对象的时候,再创建,对于hibernate来说 //才真正的发出查询语句,主要是为了提高性能,lazy是hibernate中非常重要的特性 //hibernate的lazy是如何实现的?采用代理对象实现,代理对象主要采用的是CGLIB库生成的 //而不是JDK的动态代理,因为JDK的动态代理只能对实现了接口的类生成代理,CGLIB可以对类 //生成代理,它采用的是继承方式 User user = (User)session.load(User.class, "4028808125534a540125534b952e0001"); System.out.println(user.getName()); user.setName("王五"); session.getTransaction().commit(); }catch(Exception e) { e.printStackTrace(); session.getTransaction().rollback(); }finally { HibernateUtils.closeSession(session); }
Load解析
调试查看会发现此时会生成一个代理类,因为没有实现接口,无法生成jdk代码,但是这里继承了第三方cglib生成了一个代理。
只有当用的时候才会执行相关的查询语句,支持延迟加载不同于get是立即加载,也就是支持lazy加载(在以后的文章会继续介绍)
返回结果
Session session = null; try { session = HibernateUtils.getSession(); session.beginTransaction(); //采用load查询不存在的数据,hibernate会抛出ObjectNotFoundException异常 User user = (User)session.load(User.class, "555554"); System.out.println(user.getName()); session.getTransaction().commit(); }catch(Exception e) { e.printStackTrace(); session.getTransaction().rollback(); }finally { HibernateUtils.closeSession(session); }
如果查询的返回结果没有,也就是对象没有找到的时候,则会抛出异常。
3. 小结
使用哪种方法,关键看自己的业务需求,没有最合适,只有更合适~相关文章推荐
- Java OCR tesseract 图像智能字符识别技术 Java代码实现
- Java OCR tesseract 图像智能字符识别技术
- Java转义字符
- java--空字符串""和null的区别
- Java中文图像识别tesseract-ocr || tif
- JNI学习5——测试数组的使用
- Spring Security form login using database
- Java垃圾回收机制
- Java-正则表达式的学习
- Java中Process类的使用与注意事项
- JNI学习4——访问数组(JNI)
- Java内存屏障和可见性
- Java OCR 图像智能字符识别技术,可识别中文
- Java知识总结---MVC模式解析之SpringMVC(三)
- Java基本注解以及了解自定义注解
- Spring boot的配置参数清单
- Spring Security Custom Login Form Annotation Example
- 编程风格(java)
- 安装Android sdk后eclipse没有出现avd的图标
- JAVA I/O使用方法