hibernate使用save持久化了实体后再改变实体的值
发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,public static void addStudent(){ sessionFactory=new AnnotationConfiguration().configure().bui
千家信息网最后更新 2024年11月30日hibernate使用save持久化了实体后再改变实体的值
public static void addStudent(){ sessionFactory=new AnnotationConfiguration().configure().buildSessionFactory(); Session session=sessionFactory.getCurrentSession(); session.beginTransaction(); Student student=new Student( "李四", 34); session.save(student); student.setName("王五"); Iteratoriterator=(Iterator ) session.createQuery("from Student").iterate(); while(iterator.hasNext()){ System.out.println(iterator.next().toString()); } session.getTransaction().commit(); }
注意
session.save(student);student.setName("王五");
session持久化了实体后,只是写入了session缓存中,commit前并没有写入数据库中,此时再改变
实体,保存到数据库的实体为修改过的实体。
public static void updateStudent(){ sessionFactory=new AnnotationConfiguration().configure().buildSessionFactory(); Session session=sessionFactory.getCurrentSession(); session.beginTransaction(); Student student=(Student) session.get(Student.class, 2); student.setName("update"); Iteratoriterator=(Iterator ) session.createQuery("from Student").iterate(); while(iterator.hasNext()){ System.out.println(iterator.next().toString()); } session.getTransaction().commit(); }
从数据库中查找id为2的记录后,此时session缓存中有了实体,直接修改实体的值,不用update,session提交后,数据库的记录依然被修改了
对于先查询再修改,
不写update,merge和
session.update(student);
session.merge(student);
都是一样的,commit后数据都会写入数据库
Student student=new Student(10,"update", 100); session.update(student);
直接new一个实体(其id=10的记录在数据库中不存在),直接update报错
org.hibernate.StaleStateException: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1
此Student对象的id设置了自增,其id=10的记录在数据库中不存在,
Student student=new Student(10,"update", 100); session.merge(student);
结果数据库保存了记录,但是id不为10,而是按照自增的结果,为6(插入前最大为5)
Student student=new Student(11,"update", 100); session.saveOrUpdate(student);
而想象中可以完成此操作的saveOrUpdate()却也报错
org.hibernate.StaleStateException: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1
Hibernate: update Student set age=?, name=? where id=?
发出的sql竟然是update,怎么不是save,应该是自动选择才对?
数据
数据库
实体
结果
缓存
王五
最大
不用
只是
对象
而是
李四
查询
选择
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全的艺术字图片
服务器硬盘灯亮红灯闪烁
广西河池电信宽带的dns服务器
社交电商软件开发
管家婆软件服务器移机
维护网络安全要坚持
网络安全必学课程
网络安全五种属性
电力系统网络安全设备
沧县网络安全宣传
注塑数据库
租云服务器能干嘛
广东综合软件开发成本价
换服务器
云顶手游各服务器名字
注册个体户网络技术服务部
免费海外云服务器
凹凸世界出现服务器维护中怎么办
资源环境数据库
三甲医院软件开发岗
服务器开启管理节点
网络安全教育微网文
ubuntu查看服务器功耗
软件开发的命名方法
进驻滴滴开展网络安全审查
云服务器远程登陆输入不了指令
大陆汽车面试软件开发
多点触摸屏软件开发
凹凸世界出现服务器维护中怎么办
高平软件开发工具