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

我正在为我正在研究的S​​pring / 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缓存? - 代码日志