首页 > 代码库 > 【Hibernate】数据Session对象的常规操作收集

【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

查询全部数据

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);

 

【Hibernate】数据Session对象的常规操作收集