首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

hibernate中executeUpdate的缓存问题

介绍: 在开发一个更新部门编号的功能中遇到了一个由hibernate缓存导致的问题,后来发现是由于hibernate的缓存机制所导致,这里记录了一下这个问题及其分析解决方法。...{使用批量更新hibernate中的executeUpdate() } 3.把插入的部门排序更新成插入位置的序号。...问题原因分析: 1 初步分析 首先怀疑执行executeUpdate方法后不会更新到缓存到hibernate的一级缓存中去,所以junit测试的时候拿到的还是原来的缓存对象。...但是你想想如果这些缓存对象的属性如果继续被其他业务所用,后果是不是很严重。 3 结论 最后结合测试完成以后的数据库的部门排序确发生变化可以推断出,应该就是hibernate的缓存的问题。...通过网上的搜索发现可以通过调用session.clear方法,手动清除一级缓存中的内容来解决这一问题。

73420

minidao集Hibernate便捷和mybatis灵活的orm

MiniDao MiniDao简介及特征 MiniDao是jeecg项目的持久化解决方案,关于jeecg,可点击,MiniDao具备实体维护和SQL分离的两大优势,考虑了mybatis和...hibernate的不足。...具有以下特征: 1.O/R mapping不用设置xml,零配置便于维护 2.不需要了解JDBC的知识 3.SQL语句和java代码的分离 4.可以自动生成SQL语句...5.接口和实现分离,不用写持久层代码,用户只需写接口,以及某些接口方法对应的sql 它会通过AOP自动生成实现类 6.支持自动事务处理和手动事务处理 7.支持与hibernate...轻量级无缝集成 8.MiniDao吸收了Hibernate+mybatis的优势,支持实体维护和SQL分离 9.SQL支持脚本语言 ※实体的增删改查不需要写sql,支持SQL

19430
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    minidao集Hibernate便捷和mybatis灵活的orm

    MiniDao MiniDao简介及特征 MiniDao是jeecg项目的持久化解决方案,关于jeecg,可点击,MiniDao具备实体维护和SQL分离的两大优势,考虑了mybatis和...hibernate的不足。...具有以下特征: 1.O/R mapping不用设置xml,零配置便于维护 2.不需要了解JDBC的知识 3.SQL语句和java代码的分离 4.可以自动生成SQL语句...5.接口和实现分离,不用写持久层代码,用户只需写接口,以及某些接口方法对应的sql 它会通过AOP自动生成实现类 6.支持自动事务处理和手动事务处理 7.支持与hibernate...轻量级无缝集成 8.MiniDao吸收了Hibernate+mybatis的优势,支持实体维护和SQL分离 9.SQL支持脚本语言 ※实体的增删改查不需要写sql,支持SQL

    20120

    HIbernate的“1+N”问题

    id:2   name:java WEB开发与实战 我们明明要查询7条记录,但是hibernate用的是8条selelct语句 为什么会出现这种情况呢?...这个主要是hibernate考虑到了一级和二级缓存的效果, 如果缓存中有我们要查询的数据 那么这时我们就不用到数据库中去查询数据,而是直接从缓存中读取我们需要的数据。...但是一旦缓存中没有我们需要的数据,那么这时hibernate就会向数据库发出请求,所以我们看到上面的 运行效果会出现“1+N”的效果;(说明缓存中并没有我们要查询的 数据) 我们要避免这种问题,方法:...:hibernate5 我们用List的时候,”1+N“的方法,就会解决,而List是只从数据库中读取数据,不会 到缓存中读取数据,但是list会把从数据库中读取的数据放入到缓存中,而Iterator...如果缓存中没有我们需要的数据,即:没有命中 这时再向数据库发出请求。所以会有”1+N“的运行效果。

    54730

    HikariPool-1 – dataSource or dataSourceClassName or jdbcUrl is required.解决方案

    这里提示 dataSource or dataSourceClassName or jdbcUrl 是必须配置的,但是我反复检查了好几遍,我的配置文件中是已经配置了的,而且我发誓没有使用多个数据源,就是之前引入过...# 配置H2 web 管理控制台的上下文 spring.h2.console.path=/h2-console #进行该配置后,h2 web console就可以在远程访问了。...因此我怀疑是Spring Boot 的自动配置不知道什么原因失效了。 Spring Boot 项目拥有智能的自动配置功能,当检测到有H2 相关数据库连接的jar 包就会进行自动配置。...所谓的自动配置根据我的理解至少需要有两个操作: 读取application.properties 配置文件中属性 然后设置到实例对象中 然后通过查资料,在org.springframework.boot.jdbc...感谢前辈的博文 springboot 2 Hikari 多数据源配置问题(dataSourceClassName or jdbcUrl is required) 代码做了精简后如下: import com.zaxxer.hikari.HikariConfig

    4.1K20

    Spring Boot 和 Hibernate 的 H2 数据库配置来进行启动测试

    希望在 Spring Boot 中配置 H2 数据库来进行功能测试。 如何进行配置能来让启动的时候自动载入数据和进行测试?...Maven 依赖 如果你的 Spring 项目中没有添加 H2 的依赖,你需要在 Maven 中添加。...spring.h2.console.path 网页界面中通过 URL 可以访问控制台的地址,这个地址可以自由和任意修改。...spring.datasource.driverClassName H2 的 JDBC 驱动名称,你需要配置这个才能够通过 JDBC 访问启动后的 H2 数据库。...spring.datasource.url Spring 项目中数据源的连接参数,在这个参数中你定义了一个数据库的名称为 scodb,在通过网页界面进行访问的时候,会提醒你输入连接参数。

    1.6K20

    Web框架中的ORM框架

    在这个过程中,视图函数不是直接通过 SQL 来操作数据库,而是通过模型类的对象属性或对象方法来操作数据库,这就是 ORM 带来的便利。...当调用模型类对象的方法时,ORM 框架会帮我们生成对应的 SQL 语句,然后对数据库进行增删改查操作。对数据库进行操作后,ORM 框架会将修改后的数据映射到模型类对象的属性中。...使用 ORM 框架,不需要直接面向数据库编程,而是定义模型类,通过类和类对象就能操作它所对应的数据表中的数据。...ORM框架可以根据我们设计的类自动帮我们生成数据库中的表,省去了我们自己在数据库中建表的过程。 配置好数据库连接信息,定义模型类,执行数据库迁移后,就可以通过类和对象完成数据增删改查操作。 ?...在开发过程中,通过简单的配置就可以轻松更换数据库,简单方便。 具有这些优点,所以 ORM 框架非常实用,很多编程语言的 Web 框架中都内置了 ORM 框架。 ?

    1.9K50

    hibernate 中对象的状态

    session中对象的状态 ? 1. 临时态 存在于jvm中,却不存在于数据库中的对象,适合以下情况: 1. 使用new关键字实例化出来的对象,还未保存到数据库中; 2....从数据库中已经删除了的对象,还存在于jvm中时。(delete方法调用后) 2. 持久态 存在于jvm中,也存在于数据库记录中,session未关闭,保持着对象与记录的同步,适合以下情况: 1....将jvm中存在的对象保存或同步到数据库中记录后对象的状态。(save、update方法调用后) 注: session中有一个map存放着被托管的对象,也就是hibernate以及缓存对象的来源。...当应用程序调用org.hibernate.Transaction的commit()方法的时候,commit()方法先清理缓存,然后再向数据库提交事务。...Hibernate之所以把清理缓存的时间点安排在事务快结束时,一方面是因为可以减少访问数据库的频率,还有一方面是因为可以尽可能缩短当前事务对数据库中相关资源的锁定时间。

    1.4K50

    Hibernate总结以及在面试中的一些问题.

    为什么要使用 ①.对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。 ②.Hibernate 是一个基于JDBC的主流持久化框架,是一个优秀的ORM 实现。...在Hibernate中提供了对实体对象的延迟加载以及对集合的延迟加载,另外在Hibernate3中还提供了对属性的延迟加载。...【此方法慎用】 在Hibernate中saveOrUpdate()方法在执行的时候,先会去session中去找存不存在指定的字段,如果存在直接update,否则save,这个时候问题就发生了。...在one-to-many关联关系中,设置inverse=”true”,由多端来维护关系表 ---- Hibernate一级缓存相关问题 1.Session中的一级缓存 Hibernate框架共有两级缓存...---- Hibernate二级缓存相关问题 1.二级缓存的相关介绍 缓存好处: 将数据库或者硬盘数据,保存在内存中,减少数据库查询次数,减少硬盘交互,提高检索效率 hibernate 共有两个级别的缓存

    1.6K120

    OEA ORM中的分页支持

    本篇博客主要描述分页的常见技术方案,以及在 OEA 框架中的分页的应用及实现原理。 分页的几种方案     分页是解决大数据量显示的有效方法。...可以看到,在数据访问层的 ORM 框架中,主要是在 IQuery 条件类型上添加了一个 Paging 方法。使用这个方法指定了 PagingInfo 后,即按给定的分页信息分页查询实体数据了。...这三种数据库中,OEA 只支持前两种大型数据库的数据库分页,主要是生成分页 SQL 进行查询。    ...在 SQLCE 中,并不支持 rowNumber 函数。所以只能考虑使用 NOT IN 的 SQL 方案。...DataReader 内存分页     提供 DataReader 方案主要是简单、同时还能与数据库无关,解决跨库问题。

    1.3K80

    hibernate框架中对象的状态

    hibernate对象状态 问题: 问题1: 主键生成策略不同,save操作时发送INSERT语句的时机不同. * native: 在保存对象时,发送SQL....问题2: 删除对象的时候,没有立刻发生DELETE语句,而是在提交事务的时候发送的....问题3: 为什么在事务环境下,通过get方法得到的对象,只要修改了属性值,会发生UPDATE语句. hibernate执行流程,不能从发送sql角度去理解,应该从对象状态方向去理解。...判断规则: 1): 对象是否有OID;———可以理解对象的Id,数据库中的主键id 2): 判断对象是否被Session所管理(在一级缓存中). 2.临时/瞬时状态 没有oid,没有被session...--->设置hibernate.cfg.xml的属性:use_identifier_rollback=true 3.删除状态 特点:此时有OID,被Session所管理中, 但是最终会被删除(我们不关心删除状态的对象

    85220

    【面试问题】mybatis 与 Hibernate的不同

    Mybatis和hibernate不同,它不完全是一个ORM框架,因为MyBatis需要程序员自己编写Sql语句。...mybatis可以通过XML或注解方式灵活配置要运行的sql语句,并将java对象和sql语句映射生成最终执行的sql,最后将sql执行的结果再映射生成java对象。...Hibernate对象/关系映射能力强,数据库无关性好,对于关系模型要求高的软件(例如需求固定的定制化软件)如果用hibernate开发可以节省很多代码,提高效率。...但是Hibernate的学习门槛高,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡,以及怎样用好Hibernate需要具有很强的经验和能力才行。...总之,按照用户的需求在有限的资源环境下只要能做出维护性、扩展性良好的软件架构都是好架构,所以框架只有适合才是最好。

    58130

    Hibernate中的一级缓存

    这是因为 Hibernate使用了一级缓存,一级缓存又叫Session缓存 在一个会话的生命期里面,他所用到的数据会使用缓冲的,第一次读的是编号为2的数据记录 第一次读的时候,内存中什么都没有,这时候就要用一条...select语句从数据库中读出一条记录,同时把这些数据放到session的缓存 里面,接下来又要读同样的数据,这时候他就不会再向数据库读取数据,而是向缓存中读取数据。...我们看看下面的运行效果就会看到,这时候会看到两条select语句, 一个session对象结束后,这是缓存中的数据会清空。 所以我们看到两条select语句。...,放入缓存中,当执行session.evict(gb);语句时,就会把 缓存中的数据移除掉。...“心狠手辣”,不让敌人有丝毫反抗的有生力量…… 这个方法会让缓存中的所有东西清除的干干净净。

    45630
    领券