zoukankan      html  css  js  c++  java
  • 【Hibernate】数据Session对象的常规操作收集

    因为Hibernate是ORM(对象关系映射)的,所以程序员是不需要写Sql语句的。所有的操作都是通过对对象的操作。

    1,原生Session

    事务管理

    Transaction tx = session.beginTransaction();//开启事务
    tx.commit();//提交事务

    查询数据

    查询user表中主键值为1的数据

    Object user = session.get(User.class, 1);

    插入数据

    向数据表中插入一条新数据

    User user=new User();
    user.setId(4);
    user.setName("jordan");
    user.setPassword("abc123");
    Transaction tx = session.beginTransaction();//开启事务
    session.save(user);
    tx.commit();//提交

    更新全部数据

    将数据表中id为4的字段全部赋值,

    如果对应的user表中的字段在插入的对象中没有给定值,那么将会赋值为null

    User user=new User();
    user.setId(4);
    user.setName("james");
    Transaction tx = session.beginTransaction();
    session.update(user);//这个会把id为4的数据,name字段值改为'james' ,password字段值改为null。
    tx.commit();

    更新部分数据

    如果只更新数据表中某行的部分字段,可以按照一下的思路

    思路:

    先把所有数据查询出来,

    然后把需要修改的数据修改掉

    再进行一次全部更新。

    这样就可以实现部分更新了

    User user = (User)session.get(User.class, 4);
    user.setPassword("abcdef");
    Transaction tx = session.beginTransaction();//开启事务
    session.update(user);
    tx.commit();//提交事务

    删除数据

    删除主键为2的数据

    User user=new User();
    user.setId(2);//以主键作为删除条件
    Transaction tx = session.beginTransaction();
    session.delete(user);
    tx.commit();

    2,HQL

    使用原生Session进行数据库操作,虽然贯彻了Hibernate的ORM特性,也就是一切都通过对象来实现,但是原生Session的缺点也明显,它只封装了基本的增删查改操作,对于复杂的情况可能就力不从心了。Hibernate提供了更加灵活的HQL语句(Hibernate Query Language),来弥补这个缺板,HQL可以由程序员自己写SQL语句,摆脱了ORM的约束。

    查询全部数据

    SQL语句:select * from user

    HQL操作:

    String hql="from User";
    Query query = session.createQuery(hql);
    List list = query.list();//查询全部数据
    for(Object user:list){
        System.out.println(user);
    }

    查找指定条件的数据

    SQL语句:select * from user where uid=2;

    HQL操作:

    String hql="from User where id=?";
    Query query = session.createQuery(hql);
    query.setInteger(0, 2);//设置参数
    Object result = query.uniqueResult();//得到唯一结果
    System.out.println(result);

    使用预定义函数

    SQL语句:select count(*) from user

    HQL操作:

    String hql="select count(*) from User";
    Query query = session.createQuery(hql);
    Object result = query.uniqueResult();//结果肯定是整形
    System.out.println(result);

    分页

    SQL语句:select * from user limit 1,2

    HQL操作:

    String hql="from User";
    Query query = session.createQuery(hql);
    query.setFirstResult(1);//查询起始位置
    query.setMaxResults(2);//指定查询的数量
    List list = query.list();
    for(Object user:list){
        System.out.println(user);
    }

    更新

    SQL语句:update user set uname='honny' where uid=1

    HQL操作:

    String hql="update User set name=? where id=?";
    Query query = session.createQuery(hql);
    query.setString(0, "honny");
    query.setInteger(1, 1);
    Transaction tx = session.beginTransaction();//开启事务
    int rows = query.executeUpdate();//得到影响的行数
    tx.commit();//提交事务
    System.out.println("影响行数:"+rows);
  • 相关阅读:
    《校园封神榜》第二阶段个人工作总结——第五天
    寻找水王2——寻找三个小水王
    站立会议04(第二次冲刺)
    站立会议03(第二次冲刺)
    站立会议02(第二次冲刺)
    站立会议01(第二次冲刺)
    测试计划
    评价cnblogs.com的用户体验
    第一次冲刺各组评价的回复
    第一次冲刺对各组的评价
  • 原文地址:https://www.cnblogs.com/HDK2016/p/7351053.html
Copyright © 2011-2022 走看看