• 使用Hibernate实现简单的增、改、删、查操作


    作为Hibernate的初学者,要真正的掌握Hibernate,从简单的增、改、删、查开始。 

    1.增加(save或persist)

     这两个方法都能实现数据的添加,主要区别在于:在没有开启事物时,save( )会执行相关的sql语句,然后在回滚,而persist根本不会执行sql语句。所以这两个方法都要在事物中才能生效。

    示例代码:

     1     Configuration conf = new Configuration();
     2     conf.configure();
     3     SessionFactory fac = conf.buildSessionFactory();
     4     Session s = fac.openSession();
     5     Transaction trans = s.beginTransaction();
     6     Student stu = new Student();
     7     stu.setAge(20);
     8     stu.setName("周杰伦");
     9     s.save(stu);//添加数据
    10     trans.commit();
    11     s.close();
    12     System.out.println("OK");


    2. 查询 (get或load)

     get和load都从数据库加载一条数据,不同在于:get会立即查询数据库,而load是一个懒加载,先返回代理对象,在使用的时候才真正的加载数据。

    示例代码:

     1     Configuration conf = new Configuration();
     2     conf.configure();
     3     SessionFactory fac = conf.buildSessionFactory();
     4     Session s = fac.openSession();
     5     Transaction trans = s.beginTransaction();
     6     Object obj = s.load(Student.class, 1);// 加载Id=1的记录
     7     Student st = (Student) obj;// 强制转型
     8     System.out.println("Name:" + st.getName());
     9     trans.commit();
    10     s.close();
    11     System.out.println("OK");

    3. 修改 (update)

     要先通过get或load得到要修改的对象,通过set修改对象的信息后,通过update方法更新到数据库。

    示例代码:

     1     Configuration conf = new Configuration();
     2     conf.configure();
     3     SessionFactory fac = conf.buildSessionFactory();
     4     Session s = fac.openSession();
     5     Transaction trans = s.beginTransaction();
     6     Object obj = s.load(Student.class, 1);// 加载Id=1的数据
     7     Student st = (Student) obj;// 强制转型
     8     st.setName("曹領雄");//修改名称
     9     s.update(st);//更新数据    
    10     trans.commit();//提交事物
    11     s.close();
    12     System.out.println("OK");
     

    4. 删除 (delete)

    要先通过get或load得到要删除的对象,然后通过delete方法删除该条记录。

    示例代码:

     1     Configuration conf = new Configuration();
     2     conf.configure();
     3     SessionFactory fac = conf.buildSessionFactory();
     4     Session s = fac.openSession();
     5     Transaction trans = s.beginTransaction();
     6     Object obj = s.load(Student.class, 1);// 加载Id=1的数据
     7     Student st = (Student) obj;// 强制转型
     8     s.delete(st);//删除该对象
     9     trans.commit();// 提交事物
    10     s.close();
    11     System.out.println("OK");

     

  • 相关阅读:
    通过日志过滤的方法,统计每天内容详情页面的PV数
    模拟开户接口,使用python脚本实现批量用户开通
    模拟开户接口,使用shell脚本实现批量用户开通
    TCP的socket资源被耗尽的问题
    excel文件使用navicat工具导入mysql的方法
    MYSQL主从同步/主主同步
    django在创建用户时设置一个默认的密码
    django 字段默认值
    django中写入数据时给密码加密
    django后台admin页面表单自定义
  • 原文地址:https://www.cnblogs.com/lxcao/p/3372763.html
Copyright © 2020-2023  润新知