java - 截断所有表,清除一级和二级 hibernate 缓存的简单方法?

标签 java unit-testing hibernate orm

我正在为我正在开发的 Spring/Hibernate 应用程序编写一些集成测试,我想在尽可能接近真实条件的情况下进行测试,其中包括使用 Hibernate 的二级缓存和提交事务。

我想知道是否有一种有效的方法可以让 Hibernate 从数据库和缓存中删除所有内容。我能想到的最好办法是对每种类型的对象使用 HQL“从 XImpl 中删除”行,但我有几十个域对象,感觉应该有更好的方法。

最佳答案

对于数据库,使用SchemaExport 工具重新创建架构:

Configuration cfg = ....;
new SchemaExport(cfg).create(false, true);

对于二级缓存,从 SessionFactory 获取对底层缓存区域的访问并逐出所有内容:

SessionFactory sf = ...;
Cache cache = sf.getCache();
cache.evictEntityRegions();
cache.evictCollectionRegions();
cache.evictQueryRegions();

对于一级缓存,好吧,只需获取一个新的Session 或调用session.clear()

关于java - 截断所有表,清除一级和二级 hibernate 缓存的简单方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3121743/

相关文章:

java - assertEquals(obj,obj) 返回失败的测试

java - SpringJUnit4ClassRunner 和 SpringRunner 有什么区别

java - 如何在 Spring Junit 中创建 session

java - Hibernate 关系注解

java - Spring MVC + Hibernate编码问题

java - hibernate 连接失败

java - Android 字符串问题 : How can I centralize all strings within my app?

java - 如何将 Javadoc 的输出转换为 MediaWiki 并将其放入 SourceForge 的 wiki?

java - 如何在编辑文本中显示 Realm 数据库结果?

java - 我可以使用带有 log4j.properties 文件的 log4j 1.x 异步运行我的日志吗?