hibernate课程 初探单表映射2-6 session详解(下)
本节主要内容:
1 介绍了getCurrentSession和opensession的区别
2 demo:通过打印比较两个session是否相同,验证两个session是否是同一session
3 demo:通过打印hashcode验证不关闭session,容易连接池溢出。
1 getCurrentSession和opensession的区别
a getCurrentSession每次获取的都是同一连接,opensession每次获取的是不同的连接。
b getCurrentSession不需要手动关闭,在提交事务之后自动关闭。opensession需要手动关闭,如果不关闭的话,连接数枯竭,容易连接池溢出.
c getCurrentSession 必须开启事务transaction,opensession不是必须(自我总结的)
2 demo1
package hibernate_001;
import java.sql.Array; import java.sql.Blob; import java.sql.CallableStatement; import java.sql.Clob; import java.sql.DatabaseMetaData; import java.sql.NClob; import java.sql.PreparedStatement; import java.sql.SQLClientInfoException; import java.sql.SQLException; import java.sql.SQLWarning; import java.sql.SQLXML; import java.sql.Savepoint; import java.sql.Statement; import java.sql.Struct; import java.util.Date; import java.util.Map; import java.util.Properties; import java.util.TimeZone; import java.util.concurrent.Executor;
import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.jdbc.Work; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.junit.After; import org.junit.Before; import org.junit.Test;
import com.ddwei.student.Student; import com.mysql.jdbc.Connection; import com.mysql.jdbc.ExceptionInterceptor; import com.mysql.jdbc.Extension; import com.mysql.jdbc.MySQLConnection; import com.mysql.jdbc.log.Log;
public class StudentTest { private SessionFactory sessionFactory; private Session session; private Transaction trasaction; @Test public void testSaveStudent(){ //获取配置对象,得到hibernate.cfg.xml配置的内容 Configuration config = new Configuration().configure(); //获取服务注册对象,获取hibernate.hbm.xml配置的内容 ServiceRegistry sry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); SessionFactory sfy = config.buildSessionFactory(sry); Session sesion1 = sfy.openSession(); Session sesion2 = sfy.openSession(); System.out.println(sesion1==sesion2); // Student student =new Student(3,"周恩来","男",new Date(),"绍兴");//创建学生对象 // session.save(student);//会话保存学生对象进入数据库 } @Test public void testSaveStudent2(){ //获取配置对象,得到hibernate.cfg.xml配置的内容 Configuration config = new Configuration().configure(); //获取服务注册对象,获取hibernate.hbm.xml配置的内容 ServiceRegistry sry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); SessionFactory sfy = config.buildSessionFactory(sry); Session sesion1 = sfy.getCurrentSession(); Session sesion2 = sfy.getCurrentSession(); System.out.println(sesion1==sesion2); // Student student =new Student(3,"周恩来","男",new Date(),"绍兴");//创建学生对象 // session.save(student);//会话保存学生对象进入数据库 }
}
demo2
package hibernate_001;
import java.sql.Array; import java.sql.Blob; import java.sql.CallableStatement; import java.sql.Clob; import java.sql.DatabaseMetaData; import java.sql.NClob; import java.sql.PreparedStatement; import java.sql.SQLClientInfoException; import java.sql.SQLException; import java.sql.SQLWarning; import java.sql.SQLXML; import java.sql.Savepoint; import java.sql.Statement; import java.sql.Struct; import java.util.Date; import java.util.Map; import java.util.Properties; import java.util.TimeZone; import java.util.concurrent.Executor;
import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.hibernate.jdbc.Work; import org.hibernate.service.ServiceRegistry; import org.hibernate.service.ServiceRegistryBuilder; import org.junit.After; import org.junit.Before; import org.junit.Test;
import com.ddwei.student.Student; import com.mysql.jdbc.Connection; import com.mysql.jdbc.ExceptionInterceptor; import com.mysql.jdbc.Extension; import com.mysql.jdbc.MySQLConnection; import com.mysql.jdbc.log.Log;
public class StudentTest2 { private SessionFactory sessionFactory; private Session session; private Transaction trasaction; @Test public void testSaveStudent(){ //获取配置对象,得到hibernate.cfg.xml配置的内容 Configuration config = new Configuration().configure(); //获取服务注册对象,获取hibernate.hbm.xml配置的内容 ServiceRegistry sry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); SessionFactory sfy = config.buildSessionFactory(sry); Session sesion1 = sfy.openSession(); sesion1.doWork(new Work() { @Override public void execute(java.sql.Connection connection) throws SQLException { // TODO Auto-generated method stub System.out.println("connection.hashcode is "+connection.hashCode()); } }); Student student =new Student(4,"周恩来","男",new Date(),"绍兴");//创建学生对象 sesion1.save(student);//会话保存学生对象进入数据库
Session sesion2 = sfy.openSession(); Student student2 =new Student(5,"周恩来","男",new Date(),"绍兴");//创建学生对象 sesion2.doWork(new Work() { @Override public void execute(java.sql.Connection connection) throws SQLException { // TODO Auto-generated method stub System.out.println("connection.hashcode is "+connection.hashCode()); } }); sesion2.save(student2);//会话保存学生对象进入数据库
} @Test public void testSaveStudent2(){ //获取配置对象,得到hibernate.cfg.xml配置的内容 Configuration config = new Configuration().configure(); //获取服务注册对象,获取hibernate.hbm.xml配置的内容 ServiceRegistry sry = new ServiceRegistryBuilder().applySettings(config.getProperties()).buildServiceRegistry(); SessionFactory sfy = config.buildSessionFactory(sry); Session sesion1 = sfy.getCurrentSession(); Transaction tran = sesion1.beginTransaction(); Student student =new Student(1,"周恩来","男",new Date(),"绍兴");//创建学生对象 sesion1.doWork(new Work(){ @Override public void execute(java.sql.Connection connection) throws SQLException { // TODO Auto-generated method stub System.out.println("connection.hashcode is "+connection.hashCode()); } }); sesion1.save(student);//会话保存学生对象进入数据库 tran.commit(); Session sesion2 = sfy.getCurrentSession(); Transaction tran2 = sesion2.beginTransaction();
Student student2 =new Student(2,"周恩来","男",new Date(),"绍兴");//创建学生对象 sesion2.doWork(new Work() { @Override public void execute(java.sql.Connection connection) throws SQLException { // TODO Auto-generated method stub System.out.println("connection.hashcode is "+connection.hashCode()); } }); sesion2.save(student2);//会话保存学生对象进入数据库 tran2.commit(); }
}
最新文章
- 非对称加密算法——RSA
- requirejs:让人迷惑的路径解析
- JS-DOM2级封装练习题--点击登录弹出登录对话框
- php栈数据结构和括号匹配算法
- 修复 VirtualBox 下 Ubuntu 14.10 屏幕分辨率问题
- 解决C#的64位打包程序,在64位机器上运行出现BadImageFormatException异常。
- ***常见复杂SQL语句(含统计类SQL)
- GridView的初级使用
- Nginx 配置基于域名的虚拟
- [POI 2015]Kinoman
- Winform/WPF中内嵌BeetleX的HTTP服务
- 高性能平滑动画_requestAnimationFrame
- Oracle创建表空间、表、一级用户授权
- JavaSpcript基础
- Memcached 集群架构与memcached-session-manager
- phantomjs 了解
- CSS修改滚动条样式
- SQL-38 创建视图
- Java基础--深克隆补充
- RuntimeError: Working outside of application context.
热门文章
- struts2 json返回试验
- 多个VSTO解决方案间传输变量
- centos运行netcore error:package: ‘Microsoft.AspNetCore.Antiforgery‘, version: ‘2.0.3‘
- Eclipse插件无法识别的解决方法汇总
- etcd代理组件的开发思想
- 《OD玩阿里云》搭建环境
- 796D(bfs)
- [Xcode 实际操作]四、常用控件-(4)UILabel文本标签的自动换行
- oracle odbc连接sqlserver 无法查询字段
- Java Script 第二章.