網站首頁 編程語言 正文
本文實例為大家分享了redis緩存數據庫中數據的具體代碼,供大家參考,具體內容如下
將數據庫的數據保存到redis緩存
當第一次查詢時,緩存沒有對應的數據,則會查詢數據庫,并將數據更新到緩存
當緩存中有對應的數據時,則會直接訪問緩存,則不查詢數據庫
這樣在性能優化上有很大的幫助
ProvinceServiceImpl
public class ProvinceServiceImpl implements ProvinceService {
? ? private ProvinceDao dao = new ProvinceDaoImpl();
? ? @Override
? ? public List<Province> findAll() {
? ? ? ? return dao.findAll();
? ? }
? ? /**
? ? ?* 使用redis緩存
? ? ?* @return
? ? ?*/
? ? @Override
? ? public String findAllJson(){
? ? ? ? //1.先從redis中查詢數據
? ? ? ? //1.1獲取客戶端連接
? ? ? ? Jedis jedis = JedisUtils.getJedis();
? ? ? ? String province_json = jedis.get("province");
? ? ? ? //2.判斷province_json數據是否為null
? ? ? ? if(province_json == null || province_json.length() == 0){
? ? ? ? ? ? //redis中沒有數據
? ? ? ? ? ? System.out.println("redis中沒有數據,查詢數據庫...");
? ? ? ? ? ? //2.1從數據庫中查詢
? ? ? ? ? ? List<Province> list = dao.findAll();
? ? ? ? ? ? //2.2將list序列化為json
? ? ? ? ? ? ObjectMapper mapper = new ObjectMapper();
? ? ? ? ? ? try {
? ? ? ? ? ? ? ? province_json = mapper.writeValueAsString(list);
? ? ? ? ? ? } catch (JsonProcessingException e) {
? ? ? ? ? ? ? ? e.printStackTrace();
? ? ? ? ? ? }
? ? ? ? ? ? //2.3將json數據存入redis中
? ? ? ? ? ? jedis.set("province", province_json);
? ? ? ? ? ? //釋放資源
? ? ? ? ? ? jedis.close();
? ? ? ? }else {
? ? ? ? ? ? System.out.println("redis中有數據,查詢緩存...");
? ? ? ? }
? ? ? ? return province_json;
? ? }
}
index.html
<!DOCTYPE html>
<html lang="en">
<head>
? ? <meta charset="UTF-8">
? ? <title>Title</title>
</head>
<script src="js/jquery-3.3.1.min.js"></script>
? ? <script>
? ? ? ? $(function (){
? ? ? ? ? ? //發送ajax請求,加載所有省份數據
? ? ? ? ? ? $.get("provinceServlet",{},function (data){
? ? ? ? ? ? ? ? //[{"id":1,"name":"北京"},{"id":2,"name":"上海"},{"id":3,"name":"廣州"},{"id":4,"name":"武漢"}]
? ? ? ? ? ? ? ? //1.獲取select
? ? ? ? ? ? ? ? var province = $("#province");
? ? ? ? ? ? ? ? //2.遍歷json數組
? ? ? ? ? ? ? ? $(data).each(function (){
? ? ? ? ? ? ? ? ? ? //3.創建<option>
? ? ? ? ? ? ? ? ? ? var option = "<option name='" + this +"'>" + this.name + "</option>";
? ? ? ? ? ? ? ? ? ? //4.調用select的append方法追加
? ? ? ? ? ? ? ? ? ? province.append(option);
? ? ? ? ? ? ? ? });
? ? ? ? ? ? });
? ? ? ? });
? ? </script>
<body>
? ? <select id="province">
? ? ? ? <option>---請選擇省份---</option>
? ? </select>
</body>
</html>
效果展示
第一次查詢時
此時可以看到redis沒有數據,所以查詢了數據庫
第二次查詢
此時可以看到redis中已經有緩存了,所以沒有查詢數據庫
注意
當數據中的數據進行增刪改時,緩存的數據依舊不會改變,所以當進行增刪改操作后,應該刪除redis中的緩存,然后在重新緩存,從而達到更新緩存的效果。
原文鏈接:https://blog.csdn.net/qq_46274901/article/details/123699904
相關推薦
- 2022-10-21 Python?NumPy教程之數組的基本操作詳解_python
- 2023-12-25 Spring @Cacheable緩存注解
- 2022-04-25 深入理解React?三大核心屬性_React
- 2022-03-19 解析OpenXml?Pptx的邊框虛線轉為WPF的邊框虛線問題_C#教程
- 2022-04-19 C#使用CancellationTokenSource?取消?Task的方法_C#教程
- 2022-11-07 go?分布式鎖簡單實現實例詳解_Golang
- 2022-03-14 idea中的子模塊無法新建class的解決方法(idea編譯沒有生成class文件)
- 2023-02-01 特定用例下的Combine全面使用詳解_Swift
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支