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

Bra*_*ugh 3 java orm unit-testing hibernate

我正在为我正在研究的S​​pring/Hibernate应用程序编写一些集成测试,我想尽可能接近真实条件进行测试,包括使用Hibernate的二级缓存和提交事务.

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

Pas*_*ent 5

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

Configuration cfg = ....;
new SchemaExport(cfg).create(false, true);
Run Code Online (Sandbox Code Playgroud)

对于二级缓存,可以访问底层缓存区域SessionFactory并逐出所有内容:

SessionFactory sf = ...;
Cache cache = sf.getCache();
cache.evictEntityRegions();
cache.evictCollectionRegions();
cache.evictQueryRegions();
Run Code Online (Sandbox Code Playgroud)

对于第一级缓存,嗯,只需获得一个新的Session或电话session.clear().