首頁 > 軟體

redis快取資料庫中資料的方法

2022-07-28 22:05:38

本文範例為大家分享了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中的快取,然後在重新快取,從而達到更新快取的效果。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com