最近在做一个项目中需要用缓存,项目持久层用的是Hibernate,然后就考虑用二级缓存来实现,但是后来项目扩展,由第三方修改数据这样缓存就会要等到失效后重新获取数据库的数据,本来这样是没问题的,可是领导貌似不接受这样的方式。然后就把缓存设置成永不过期,然后自己定时更新数据加入到Ehcache中去,研究源码发现Hibernate在查询到结果后会把结果集的实体封装成CacheKey、CacheEntry put到二级缓存中去,在put的时候有个判断就是已经存在二级缓存中的key不会被替换,而要求是替换最新的数据。于是就一样画葫芦自己封装CacheKey、CacheEntry 然后put进去,代码. Read More
bat不怎么会啊,研究好久才写了个能用的。echo offset BAK_Dir=F:\share\JavaServer\224DB_BackUP ::yyyy-MM-dd-hhmmssfor /f "tokens=1-4 delims=/:. " %%i in ("%date:~0,10%-%time%") do (set ymd=%%i%%j%%k%%l)if not exist %BAK_Dir% md %BAK_Dir% cd /d C:\Program Files\MySQL\MySQL Server 5.5\bin\ mysqldump.ex Read More
获取SRC目录InputStream input=当前ClassName.class.getClassLoader().getResourceAsStream("hibernate.cfg.xml");获取编译后的bin目录String binPath=HibernateSessionFactory.class.getClass().getResource("/").getPath(); Read More