hibernate增删改查操作代码

所属分类: 软件编程 / java 阅读数: 25
收藏 0 赞 0 分享

Hibernate对数据删除操作

删除User表中个一条数据,是需要更具User表的主键id值来删除的。首先根据id值向数据库中查询出来对应的对象。可以采用两种方式一是session的get方法,一个是session的load方法。

Session的Get方法:调用这个方法会返回一个Object对象。然后我们对其强制转换。Useruser = (User)session.get(User.class,” 402881e5441c035e01441c0360510003”); 当我们传递id值在数据中查找没有相应的结果时,get方法会返回一个null值。

   区别:get方法加载的时候会立刻发出sql语句去查询,而load方法在执行的时候没有立刻的发出sql去查询,生成一个代理User,没有生成真正的User。当我们真正的去用这个user的时候才会加载真正的User。Load()支持延迟加载,而Get()不支持延迟加载。Get加载的对象不存在时返回的是null对象,而Load()加载对象不存在时会抛出ObjectNotFoundException异常。

   Session的Load方法:同样是调用这个方法返回一个Object对象,再进行强制转换。

然后我们通过get或load加载上来对应user表id的对象,再调用session的delete方法删除该对象同时删除表中的一条记录,代码如下所示。

第一种删除方式。         

publicvoid testDel1()
   {
    Sessionsession =null;
    
    try
    {
     session= HibernateUtils.getSession();
     //开启事务.
     session.beginTransaction();
     //采用load查询不存在的数据,hibernate会抛出object not found exception
     Useruser = (User)session.load(User.class,"402881e5441c035e01441c0360510003");
     
     //删除表中的记录.
     //删除,建议用此种方式删除,先加载再删除.
     session.delete(user);
     
     //提交事务.把内存的改变提交到数据库上.
     session.getTransaction().commit();
     
    }catch(Exception e){
     e.printStackTrace();
     session.getTransaction().rollback();
    }finally{
     HibernateUtils.closeSession(session);
    }
    
   }

 第二种删除方式,手动构造detached对象再删除

代码如下所示。

//测试方法以test开头.测试del方法.返回存在的加载的.
   publicvoid testDel2()
   {
    Sessionsession =null;
    
    try
    {
     session= HibernateUtils.getSession();
     //开启事务.
     session.beginTransaction();
     
     //手动构造的Detached对象.
     User user =new User();
     user.setId("402881e4441b3d1c01441b3f5dfe0001");
     session.delete(user);
     
     
     //提交事务.把内存的改变提交到数据库上.
     session.getTransaction().commit();
     
    }catch(Exception e){
     e.printStackTrace();
     session.getTransaction().rollback();
    }finally{
     HibernateUtils.closeSession(session);
    }
    
   }

Hibernate对数据查询操作

一般查询,代码如下所示。

//查询方法.
 publicvoid testQuery1()
 {
  Sessionsession =null;
  try
  {
  session= HibernateUtils.getSession();
  
  session.beginTransaction();
  //参数是一个字符串,是HQL的查询语句.注意此时的的UserU为大写,为对象的,而不是表的.
  Queryquery = session.createQuery("from User");
  
  //使用List方法.
  List userList = query.list();
  //迭代器去迭代.
  for(Iterator iter=userList.iterator();iter.hasNext();)
  {
   Useruser =(User)iter.next();
   System.out.println("id="+user.getId() + "name="+user.getName());
  }
  
  session.getTransaction().commit();
  }catch(Exception e){
  e.printStackTrace();
  session.getTransaction().rollback();
  }finally{
  HibernateUtils.closeSession(session);
  }
 }

 分页查询,代码如下所示。

//分页查询,从什么地方查,查几个;
 publicvoid testQuery2()
 {
  Sessionsession =null;
  try
  {
  session=HibernateUtils.getSession();
  session.beginTransaction();
  //参数是一个字符串,是HQL的查询语句.注意此时的的UserU为大写,为对象的,而不是表的.
  Queryquery = session.createQuery("from User");
  //从第一个开始查起.可以设置从第几个查起.
  query.setFirstResult(0);
  //最大条数为两个
  query.setMaxResults(2);
  //使用List方法.
  List userList = query.list();
  //迭代器去迭代.
  for(Iterator iter=userList.iterator();iter.hasNext();)
  {
   Useruser =(User)iter.next();
   System.out.println("id="+user.getId() + "name="+user.getName());
  }
  session.getTransaction().commit();
  }catch(Exception e){
  e.printStackTrace();
  session.getTransaction().rollback();
  }finally{
  HibernateUtils.closeSession(session);
  }
 }

Hibernate对数据更新操作

手动构造detached对象,调用session的update()方法,代码如下所示。          

 //测试方法以test开头.测试update方法.返回存在的加载的.
   publicvoid testUpdate1()
   {
    Sessionsession =null;
    try
    {
     session= HibernateUtils.getSession();
     //开启事务.
     session.beginTransaction();
     //采用load查询不存在的数据,hibernate会抛出object not found exception
     //手动构造的Detached对象.
     Useruser =newUser();
     user.setId("402881e5441bfb0601441bfb075b0002");
     user.setName("周六");
     session.update(user);
     //提交事务.把内存的改变提交到数据库上.
     session.getTransaction().commit();
    }catch(Exception e){
     e.printStackTrace();
     session.getTransaction().rollback();
    }finally{
     HibernateUtils.closeSession(session);
    }
   }

加载对象,调用session的update()方法,让对象处于持久化状态的时候进行更新操作,代码如下所示。

 //测试方法以test开头.测试update方法.返回存在的加载的.
   publicvoid testUpdate2()
   {
    Sessionsession =null;
    try
    {
     session= HibernateUtils.getSession();
     //开启事务.
     session.beginTransaction();
     //采用load查询不存在的数据,hibernate会抛出object not found exception
     //先把要更新的查出来.
     //建议采用此种方式,先加载再更新的方式.
     Useruser = (User)session.load(User.class,"402881e5441bfb0601441bfb075b0002");
     //查出来的话就直接放入了.处于持久化状态.
     user.setName("周日");
     //显示的调用,因为为持久化状态也可以不显示调用.
     session.update(user);
     //提交事务.把内存的改变提交到数据库上.
     session.getTransaction().commit();
    }catch(Exceptione){
     e.printStackTrace();
     session.getTransaction().rollback();
    }finally{
     HibernateUtils.closeSession(session);
    }
   }

以上所述是小编给大家介绍的hibernate增删改查操作代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

更多精彩内容其他人还在看

Java的面向对象编程基本概念学习笔记整理

这篇文章主要介绍了Java的面向对象编程基本概念学习笔记整理,包括类与方法以及多态等支持面向对象语言中的重要特点,需要的朋友可以参考下
收藏 0 赞 0 分享

Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法

这篇文章主要介绍了Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

基于Java实现杨辉三角 LeetCode Pascal's Triangle

这篇文章主要介绍了基于Java实现杨辉三角 LeetCode Pascal's Triangle的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java中Spring获取bean方法小结

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,如何在程序中获取Spring配置的bean呢?下面通过本文给大家介绍Java中Spring获取bean方法小结,对spring获取bean方法相关知识感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

如何计算Java对象占用了多少空间?

在Java中没有sizeof运算符,所以没办法知道一个对象到底占用了多大的空间,但是在分配对象的时候会有一些基本的规则,我们根据这些规则大致能判断出来对象大小,需要的朋友可以参考下
收藏 0 赞 0 分享

剖析Java中的事件处理与异常处理机制

这篇文章主要介绍了Java中的事件处理与异常处理机制,讲解Java是如何对事件或者异常作出响应以及定义异常的一些方法,需要的朋友可以参考下
收藏 0 赞 0 分享

详解Java的Struts2框架的结构及其数据转移方式

这篇文章主要介绍了详解Java的Struts2框架的结构及其数据转移方式,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

Java封装好的mail包发送电子邮件的类

本文给大家分享了2个java封装好的mail包发送电子邮件的类,并附上使用方法,小伙伴们可以根据自己的需求自由选择。
收藏 0 赞 0 分享

在Java的Struts中判断是否调用AJAX及用拦截器对其优化

这篇文章主要介绍了在Java的Struts中判断是否调用AJAX及用拦截器对其优化的方法,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

java多线程Future和Callable类示例分享

JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们就来研究下Future和Callab
收藏 0 赞 0 分享
查看更多