您好,登錄后才能下訂單哦!
這篇“redis如何緩存數據庫中數據”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“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中的緩存,然后在重新緩存,從而達到更新緩存的效果。
以上就是關于“redis如何緩存數據庫中數據”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。