内容简介:不要以为这是可能的.列表与LT;整数>将反对getContactList的返回值的关键字保存在Cache中.因此,除非输入到getContactList的ID列表包含与先前调用之一完全相同的ID,否则将是缓存未命中并且将从DB获取数据. (注意:如果两个列表完全包含相同的元素并且顺序相同,则认为它们是相同的)一种选择是改变你的方法getContactList(名单<整数> contactIdList)到getContact(整数ID) – 在这种情况下,它可能需要一段时间来构建高速缓存,但一旦对于给定ID的
4.1.4应用程序中使用了最新的Ehcache.我所拥有的是:
class Contact{ int id; int revision; } @Cacheable("contacts") public List<Contact> getContactList(List<Integer> contactIdList) { return namedJdbc.queryForList("select * from contact where id in (:idlist)", Collections.singletonMap("idlist", contactIdList)); } @CachePut(value="contact", key = "id") public void updateContact(Contact toUpdate) { jdbctemplate.update("update contact set revision = ? where id = ?", contact.getRevision(), contact.getId()); }
我想要实现的是,联系人存储在缓存中,当我再次调用getContactList方法时,从缓存中检索id已经缓存的所有联系人,并且应该正常查询其他联系人然后缓存.然后,此缓存应在更新时更新缓存的联系人实体.
我使用普通的Spring JDBC和Ehcache,没有JPA,也没有Hibernate.
不要以为这是可能的.列表与LT;整数>将反对getContactList的返回值的关键字保存在Cache中.
因此,除非输入到getContactList的ID列表包含与先前调用之一完全相同的ID,否则将是缓存未命中并且将从DB获取数据. (注意:如果两个列表完全包含相同的元素并且顺序相同,则认为它们是相同的)
一种选择是改变你的方法getContactList(名单<整数> contactIdList)到getContact(整数ID) – 在这种情况下,它可能需要一段时间来构建高速缓存,但一旦对于给定ID的联系是在缓存中,DB不会用于在将来的电话中重新获取它.
虽然不优雅,但另一种选择是在getContactList方法中手动进行缓存.
翻译自:https://stackoverflow.com/questions/31220740/spring-cacheable-methods-with-lists
以上所述就是小编给大家介绍的《带有列表的Spring @Cacheable方法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- python – 带有分档范围的熊猫条形图
- BSPreloadTableVew带有预加载功能的tableView
- 是否可以从管道上传带有cURL的文件?
- KDevelop 5.4 正式发布,带有 Meson 支持
- Vulkan 1.1.128 发布,带有性能查询扩展
- HBase无法创建带有snappy压缩属性的表
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
统计思维:程序员数学之概率统计
Allen B.Downey / 张建锋、陈钢 / 人民邮电出版社 / 2013-5 / 29.00元
代码跑出来的概率统计问题; 程序员的概率统计开心辞典; 开放数据集,全代码攻略。 现实工作中,人们常被要求用数据说话。可是,数据自己是不能说话的,只有对它进行可靠分析和深入挖掘才能找到有价值的信息。概率统计是数据分析的通用语言,是大数据时代预测未来的根基。 站在时代浪尖上的程序员只有具备统计思维才能掌握数据分析的必杀技。本书正是一本概率统计方面的入门图书,但视角极为独特,折......一起来看看 《统计思维:程序员数学之概率统计》 这本书的介绍吧!