我们知道hibernate的核心就是对数据库的操作,里面的核心接口就是org.hibernate.Session接口。要想对数据库操作我们就要理清楚对象在整个操作中的所属的状态(Transient,Persistent,Detached)。就像马士兵老师在视频中所说的,我们并不必死抠这些字眼,我们通过自己编写测试类就可以他们之间不同的区别。
其实三种状态各自的不必总结那么多,只是一个重要的地方就是Transient状态里面的对象是没有id的。
session中常用的方法是save(),update(),saveOrUpdate(),get(),load(),delete(),clear(),flush()这些
其中大学期间我其实对get和load方法都不是太熟悉,死记硬背才在考试中答题,现在想起完全没有这个必要。我们可以根据配置好的hibernate环境来进行junit测试。
首先我们进行get()方法进行测试。
这里我们首先建立一个实体类,StudentEntity.Java 和数据库中student所对应
package com.cwnu.entities; import javax.persistence.*; import java.io.Serializable; /** * Created by yangy on 2015/12/19. */ @Table(name = "student") @Entity public class StudentEntity implements Serializable{ private int id; private String name; @Id @Column(name = "id") @GeneratedValue(strategy = GenerationType.AUTO) private int getId() { return id; } public void setId(int id) { this.id = id; } @Column(name = "name") public String getName() { return name; } public void setName(String name) { this.name = name; } }
junit类都是idea编译环境给我们配置好了,这里我们要注意,要使用getCurrentSession()来操作的话,我们首先要在Junit类中加上@Transaction注解,下面是相关的测试方法:
@Test public void testGetOrLoad() { Session session = sessionFactory.getCurrentSession(); StudentEntity student = (StudentEntity)session.get(StudentEntity.class, 1); //StudentEntity student_load = (StudentEntity)session.load(StudentEntity.class,1); String name = student.getName(); }
先测试get方法,我们发现一旦我们只是拿student这个实体操作,get方法是会输出相关的sql查询语句的,而我们注释掉get方法,换load方法的话,load方法执行拿student这个实体的数据是没有输出相应的sql语句的。但是我们在对student类进行操作的时候,这时才输出相关的语句.
所以我们看出get()和load()之间的差别:
get()每次执行都会执行sql语句,不会延迟。load()方法只是会在我们对拿到的实体进行操作的时候才去执行查询,拿到相应的实体信息。load方法返回的是一个代理对象(马士兵老师视频)。无论是get还是load首先都会查一级缓存(session)中有没有相应的对应值,如果没有,再去数据库进行查找。
clear()方法是对session里面的缓存进行了清理,测试这个方法我们可以根据下面的Junit进行测试:
@Test public void testClear() { Session session = sessionFactory.getCurrentSession(); session.get(StudentEntity.class,1); session.clear(); session.get(StudentEntity.class,1); }
如果我们把session.clear()注释掉的话,我们就可以看到只执行了一条sql语句
flush()方法是是对数据库同步的一条语句,执行完这个后立即刷新到数据库。粗浅的来看哈,其实里面还是有很多东西,比如FlushMode这个类,我们默认设置的是FlushMode.AUTO,这个一般不修改,只是为了以后的性能调优。其实我们在执行事务的时候,事务完成之后它会帮我们执行flush()方法。只是我们在进行大规模插入的时候,我们经常可以看到下面的操作:
Session session = sessionFactory.openSession(); Transaction tx = session.beginTransaction(); for ( int i=0; i<100000; i++ ) { Customer customer = new Customer(.....); session.save(customer); if ( i % 20 == 0 ) { //20, same as the JDBC batch size //flush a batch of inserts and release memory: session.flush(); session.clear(); }} tx.commit();session.close();
这样做的目的就是避免大量插入,造成session里面内存溢出,所以我们定时清理一下就可以避免这个问题。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持小牛知识库!
本文向大家介绍django session完成状态保持的方法,包括了django session完成状态保持的方法的使用技巧和注意事项,需要的朋友参考一下 本例使用登录页面演示,session的状态保持功能。 说明:因为http是无状态的,客户端请求一次页面后,就结束了,当再次访问时,服务器端并不知道浏览器此访问过什么。所以这样就需要状态保持功能,状态保存有两种方式:session和cookie都
本文向大家介绍PHP中session跨子域的三种实现方法,包括了PHP中session跨子域的三种实现方法的使用技巧和注意事项,需要的朋友参考一下 在之前做东西的时候session一般就直接存在数据库中这样就能解决跨域不仅仅是跨子域,但是今天遇到这个问题是,自己要在别人现有的东西上面做修改。由于仅仅是子域当时就想肯定有简单的解决方法,度娘了找到了三种解决办法: Session主要分两部分: 一个是
在接口流中: 中间操作可分为有状态和无状态。它们影响并行流的结果。 只有两个终端操作是非确定性方法:findAny()和forEach(Consumer)。它们影响并行流的结果。 如果中间无状态操作执行惰性操作,它们可能会产生副作用。这会影响并行Stream的结果。 中间操作可分为以下几类: 有状态 不同的() 排序() 极限(长l) 跳过(长l) 无国籍 地图(功能f) 以下是我的两个问题: >
本文向大家介绍Java中设置session超时(失效)的三种方法,包括了Java中设置session超时(失效)的三种方法的使用技巧和注意事项,需要的朋友参考一下 1.在web容器中设置(此处以tomcat为例) 在tomcat-5.0.28\conf\web.xml中设置,以下是tomcat 5.0中的默认配置: Tomcat默认session超时时间为30分钟,可以根据需要修改,负数或0为不限
本文向大家介绍jQuery显示和隐藏 常用的状态判断方法,包括了jQuery显示和隐藏 常用的状态判断方法的使用技巧和注意事项,需要的朋友参考一下 显示:show() display:block; 隐藏:hide() display:none; 当显示和隐藏切换的时候,需要判断此刻是显示还是隐藏,那判断条件常用以下几种方法: 1.if(thisNode.is(':hidden')){....
本文向大家介绍Python3获取cookie常用三种方案,包括了Python3获取cookie常用三种方案的使用技巧和注意事项,需要的朋友参考一下 方案一: 利用selenium+phantomjs无界面浏览器的形式访问网站,再获取cookie值: 方案二: 利用cookielib库获取: (1)Python2 (2)Python3 方案三: 利用requests库获取: Python3 以上就是