1、 对象状态及生命周期

瞬时状态:

持久状态:

游离状态:

2、 new->save->close->update

 public void testSave(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//构造对象--瞬时状态
user = new User();
user.setName("刘德华");
user.setPwd("2222");
//持久状态,user被session管理,并且id有值--oid
session.save(user);
//在持久状态下;脏数据检查:当提交事务,清理缓存时发现session中数据
//和数据库中数据不一致时,将会把session中的数据更新到数据库中
user.setName("学友");
//在保存以后 再修改对象 那么将会产生2条sql语句,那么效率较低,建议在save前修改
session.flush();
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
HibernateUtil.closeSession();
}
//user:游离状态
System.out.println("姓名:"+user.getName());
user.setName("朝伟");
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//持久状态
session.update(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
HibernateUtil.closeSession();
}
}

3、get/load(持久)->delete(瞬时); get/load(持久)->colse(游离)

 @Test
public void testLoad(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//持久状态
//load方法 相当于 之前的getById
//如果load查询的数据不存在,那么 抛出异常
//load不会立即查询数据,当使用的时候再查找数据
user = (User)session.load(User.class,1) ;
//System.out.println(user);
System.out.println("姓名:"+user.getName());
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
HibernateUtil.closeSession();
}
}
@Test
public void testGet(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//持久状态
//get方法 相当于 之前的getById
//如果get查询的数据不存在,那么返回null
//get方法会立即查询数据(session--数据库)
user = (User)session.get(User.class, 1) ;
System.out.println(user);
user.setName("张三");
//System.out.println("姓名:"+user.getName());
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//游离状态
user.setName("siggy");
System.out.println("============");
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//持久
session.update(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
}
@Test
public void testGet1(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//持久状态
//get方法 相当于 之前的getById
//如果get查询的数据不存在,那么返回null
//get方法会立即查询数据(session--数据库)
user = (User)session.get(User.class, 2) ;
session.delete(user);
//瞬时状态
user.setName("王五");
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//瞬时状态 }

4、 update方法:先获取对象再更新

 @Test
public void testUpdate(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//手动创建对象 可以被更新,需要指定id
//当指定id不存在时 会抛异常
user = new User();
user.setId(10);
user.setName("paul");
session.update(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//瞬时状态 }
@Test
public void testUpdate1(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//手动创建对象 可以被更新,需要指定id
//当指定id不存在时 会抛异常
user = (User)session.get(User.class, 1);
user.setName("t_bag");
user.setPwd("3333");
session.update(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//瞬时状态
}

5、delete方法:先更新 再删除—》可以避免异常

 @Test
public void testDelete(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
//手动构建对象 并指定id可以从数据库删除
//如果指定id不存在 将抛异常
user = new User();
user.setId(3);
session.delete(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//瞬时状态
}
@Test
public void testDelete1(){
Session session=null;
Transaction tx=null;
User user=null;
try {
session = HibernateUtil.getSession();
tx = session.beginTransaction();
user = (User)session.get(User.class, 1);
if(user!=null)
session.delete(user);
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
}finally{
//关闭session
HibernateUtil.closeSession();
}
//瞬时状态
}

对象生命周期及crud操作的更多相关文章

  1. Hibernate 对象的生命周期及CRUD操作

    对象状态及生命周期 1.Transient(瞬时状态):new的对象为瞬时态 session中没有数据,数据库中没有数据. 2.Persistent(持久状态):被session管理的对象为持久状态, ...

  2. ASP.NET Core Web API下事件驱动型架构的实现(二):事件处理器中对象生命周期的管理

    在上文中,我介绍了事件驱动型架构的一种简单的实现,并演示了一个完整的事件派发.订阅和处理的流程.这种实现太简单了,百十行代码就展示了一个基本工作原理.然而,要将这样的解决方案运用到实际生产环境,还有很 ...

  3. Python学习手册之内部方法、操作符重载和对象生命周期

    在上一篇文章中,我们介绍了 Python 的类和继承,现在我们介绍 Python 的内部方法.操作符重载和对象生命周期. 查看上一篇文章请点击:https://www.cnblogs.com/dust ...

  4. JAVAEE_Servlet_03_Servlet对象生命周期

    Servlet的对象声明周期 * 什么是对象生命周期? - 生命周期表示一个JAVA对象从创建到销毁的过程是一个生命周期 * Servlet对象生命周期 1. Servlet对象创建 无参构造 2. ...

  5. Hibernate的三种状态及对象生命周期

        理解Hibernate的三种状态,更利于理解Hibernate的运行机制,这些可以让你在开发中对疑点问题的定位产生关键性的帮助. 三种状态 临时状态(Transient):在通过new关键字, ...

  6. .Net组件程序设计之对象生命周期

    .Net组件程序设计之对象生命周期 .NET 垃圾回收 IDisposable() Using语句 .NET 垃圾回收 是CLR管理着垃圾回收器,垃圾回收器监控着托管堆,而我们使用的对象以及系统启动是 ...

  7. Ninject之旅之三:Ninject对象生命周期

    摘要 DI容器的一个责任是管理他创建的对象的生命周期.他应该决定什么时候创建一个给定类型的对象,什么时候使用已经存在的对象.他还需要在对象不需要的时候处理对象.Ninject在不同的情况下管理对象的生 ...

  8. iOS视图控制对象生命周期

    iOS视图控制对象生命周期-init.viewDidLoad.viewWillAppear.viewDidAppear.viewWillDisappear.viewDidDisappear的区别及用途 ...

  9. IOS 视图控制对象生命周期-init、viewDidLoad、viewWillAppear、viewDidAppear、viewWillDisappear等的区别及用途

    iOS视图控制对象生命周期-init.viewDidLoad.viewWillAppear.viewDidAppear.viewWillDisappear.viewDidDisappear的区别及用途 ...

随机推荐

  1. C专家编程学习 1

    1.C语言的基本数据类型直接与底层硬件相对应. 2#define 是可能出现问题 1 2 3 4 5 #define a(y) a_ex(y) a(x)被扩展为 a_ex(x)   #define a ...

  2. launch文件概述---1

    摘要: 原创博客:转载请表明出处:http://www.cnblogs.com/zxouxuewei/ 资源链接:http://wenku.baidu.com/link?url=PhyN3C6ghqo ...

  3. Android——ListView

    1.ArryAdapter: arry_adapter的layout文件: <?xml version="1.0" encoding="utf-8"?&g ...

  4. 【NOIP2008】双栈排序

    感觉看了题解还是挺简单的,不知道当年chty同学为什么被卡了呢么久--所以说我还是看题解了 原题: Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将 ...

  5. Vimdiff---VIM的比较和合并工具

    本文来自IBMDW   http://www.ibm.com/developerworks/cn/linux/l-vimdiff/ 源程序文件(通常是纯文本文件)比较和合并工具一直是软件开发过程中比较 ...

  6. log tree(merge)

    http://www-users.cs.umn.edu/~he/diff/p256-severance.pdf http://www.eecs.harvard.edu/~margo/cs165/pap ...

  7. elasticsearch介绍集群,模拟横向扩展节点、节点宕机、改变分片

        出处:[http://www.cnblogs.com/dennisit/p/4133131.html] ,防楼主删博,故保留一份! elasticsearch用于构建高可用和可扩展的系统.扩展 ...

  8. timestamp 与 rowversion

    联机丛书: timestamp timestamp 这种数据类型表现自动生成的二进制数,确保这些数在数据库中是唯一的.timestamp 一般用作给表行加版本戳的机制.存储大小为 8 字节. 注释 T ...

  9. EasyUI之DataGrid使用

    http://blog.csdn.net/liovey/article/details/9173931 背景介绍: 原 先项目采用普通的jsp页面来做为前端显示,用户体验差,并且为了实现某一种效果需要 ...

  10. 检测php网站是否已经被攻破

    from :http://www.gregfreeman.org/2013/how-to-tell-if-your-php-site-has-been-compromised/ http://drop ...