hibernate使用save持久化了实体后再改变实体的值
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,public static void addStudent(){ sessionFactory=new AnnotationConfiguration().configure().bui
千家信息网最后更新 2025年01月20日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安全错误
数据库的锁怎样保障安全
青浦区一站式网络技术答疑解惑
怀旧服怎么重新下载服务器
jsp增删改查数据库
海南创新网络技术服务怎么样
丹东服务器在哪里
数据库表分号
下列属于网络安全服务器
如何查看服务器ip地址
上海办公软件开发系统开源
嵌入式软件开发大学
服务器约在15分钟后关闭
物理因素如何破坏网络安全
奉化敏捷软件开发教程
广州英伦网络技术有限公司
广州诺克网络技术
北京it软件开发来电咨询
软件开发服务几个点
软件开发程序 培训班
云服务器搭建sk5可以玩游戏吗
怎么取消手机服务器阻止
公司服务器登录
怎么上公司服务器
农业银行总行软件开发部成都
网络安全教育与我们的成长
网络安全可行性研究报告
网络技术能从事的工作
网络安全讲座的感想300字
成都宇辰互联网科技
行研数据库维护
八开纸网络安全手抄报教学