springboot的@cachePut在使用数据库更新数据时一些奇怪的问题
2018-10-28 14:51
176 查看
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_38680405/article/details/83474556
在使用@CachePut来更新缓存的时候,控制台报如下错误:
[code]java.lang.ClassCastException: java.base/java.lang.Integer cannot be cast to java.base/java.util.List at cn.dxszxw.service.serviceImpl.ExamServiceImpl$$EnhancerBySpringCGLIB$$3dbd9456.getAllFalses(<generated>) ~[classes/:?] at *********.controller.xcxDataController.getAllFalses(xcxDataController.java:1151) ~[classes/:?] at jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:?] at jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:?] at jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:?] at java.lang.reflect.Method.invoke(Method.java:564) ~[?:?] at org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:209) ~[spring-web-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:136) ~[spring-web-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:102) ~[spring-webmvc-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:877) ~[spring-webmvc-5.0.5.RELEASE.jar:5.0.5.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:783) ~[spring-webmvc-5.0.5.RELEASE.jar:5.0.5.RELEASE]
java.base/java.lang.Integer cannot be cast to java.base/java.util.List就是在更新缓存的时候,我用数据库更新的返回值为int,但是更新缓存@cachePut的值是list了
解决办法就是把int改成list就行了,具体实施过程就是把list弄成int那样能识别出数据库是不是插入数据成功了。
问题来了。。。。当我改成int成list的时候,能自动更新了ExamFalses这个list缓存了,但是更新的是只有插入数据的缓存,之前的缓存被清空了,最后只剩下更新的缓存。可能过程我理解错了,但是我觉得如果这样更新的话还不如在每次插入数据的时候先把缓存删除掉,然后要调用getAllFalses方法的时候再重新存入缓存快而省事。
总结:如果用list类型的存缓存,不推荐用@cachePut来更新缓存。
如理解有误,望指出
阅读更多相关文章推荐
- 使用Linq 更新数据库时遇到的一些问题及解决办法
- 关于在SSH项目中使用OpenSessionInViewFilter过滤器后数据库数据不更新的问题
- FMDB性能优化问题。使用FMDB事务批量更新数据库速度问题。(亲测可以呀---740条数据用和不用事务效率差别20倍+)
- 使用Linq 更新数据库时遇到的一些问题及解决办法
- 使用Vista的一些问题[持续更新]
- [转载]使用日期/时间型数据类型的一些基本问题(ACCESS中测试)
- 巧妙使用JQuery Clone 添加多行数据,并更新到数据库
- 使用 SQL 语句从数据库一个表中随机获取一些数据
- 一起谈.NET技术,使用LINQ to SQL更新数据库(上):问题重重
- 使用EntityFramework访问数据时的一些效率问题
- 关于使用BoundsCheck的一些问题汇总[持续更新]
- Castle ActiveRecord 在查询时会自行更新数据库数据的问题 (ZT)
- asp.net 使用驻留在页面中的Cache缓存常用可定时更新的数据
- PostgreSQL: 数据迁移之序列问题(也可以使用在所有使用序列数据库上,比如Oracle)
- 在Windows系统下Git使用过程中配到的一些问题汇总(持续更新)
- sqlplus使用copy命令在两个数据库之间更新数据
- 使用 ajax json(getJSON)从服务器读取数据,在IE下不更新问题解决
- VS2008使用Access数据库,不能更新数据库中数据的原因
- 使用 SQL 语句从数据库一个表中随机获取一些数据
- Access使用参数化UPDATE数据时,数据无法更新的问题