hibernate使用save持久化了实体后再改变实体的值
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,public static void addStudent(){ sessionFactory=new AnnotationConfiguration().configure().bui
千家信息网最后更新 2025年11月07日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("王五"); Iterator iterator=(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"); Iterator iterator=(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安全错误
数据库的锁怎样保障安全
数据库恢复挂起状态怎么处理
描述用于软件开发的原型模型
宝山区会计软件开发技术指导
软件开发费用标准和依据
新疆互联网科技股份有限公司
网络安全问题微课视频
大话西游2防沉迷服务器
网络安全评估公司
自身如何提高网络安全意思
数字媒体类和网络技术类哪个好
本地与云端数据库同步
戴尔g15做软件开发
工业园区创新软件开发专业服务
江西软件开发专业哪个学校好
软件开发eif
公用网络安全嘛
网络安全海报用语
信息网络安全领域学术期刊
哔咔服务器选
互联网科技图片壁纸
贵广网络技术支持岗内容
sql数据库如何查询特定的内容
国家网络安全宣传活动安徽
短信验证服务器架构
业务软件开发案例
中国传统数据库架构
李春葆数据库pdf
城厢区飞天网络技术
霸州微型企业财务软件网络技术
软件开发人员管理原则