redis緩存數(shù)據(jù)庫(kù)中數(shù)據(jù)的方法
本文實(shí)例為大家分享了redis緩存數(shù)據(jù)庫(kù)中數(shù)據(jù)的具體代碼,供大家參考,具體內(nèi)容如下
將數(shù)據(jù)庫(kù)的數(shù)據(jù)保存到redis緩存
當(dāng)?shù)谝淮尾樵儠r(shí),緩存沒(méi)有對(duì)應(yīng)的數(shù)據(jù),則會(huì)查詢數(shù)據(jù)庫(kù),并將數(shù)據(jù)更新到緩存
當(dāng)緩存中有對(duì)應(yīng)的數(shù)據(jù)時(shí),則會(huì)直接訪問(wèn)緩存,則不查詢數(shù)據(jù)庫(kù)
這樣在性能優(yōu)化上有很大的幫助
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中查詢數(shù)據(jù) ? ? ? ? //1.1獲取客戶端連接 ? ? ? ? Jedis jedis = JedisUtils.getJedis(); ? ? ? ? String province_json = jedis.get("province"); ? ? ? ? //2.判斷province_json數(shù)據(jù)是否為null ? ? ? ? if(province_json == null || province_json.length() == 0){ ? ? ? ? ? ? //redis中沒(méi)有數(shù)據(jù) ? ? ? ? ? ? System.out.println("redis中沒(méi)有數(shù)據(jù),查詢數(shù)據(jù)庫(kù)..."); ? ? ? ? ? ? //2.1從數(shù)據(jù)庫(kù)中查詢 ? ? ? ? ? ? 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數(shù)據(jù)存入redis中 ? ? ? ? ? ? jedis.set("province", province_json); ? ? ? ? ? ? //釋放資源 ? ? ? ? ? ? jedis.close(); ? ? ? ? }else { ? ? ? ? ? ? System.out.println("redis中有數(shù)據(jù),查詢緩存..."); ? ? ? ? } ? ? ? ? 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 (){ ? ? ? ? ? ? //發(fā)送ajax請(qǐng)求,加載所有省份數(shù)據(jù) ? ? ? ? ? ? $.get("provinceServlet",{},function (data){ ? ? ? ? ? ? ? ? //[{"id":1,"name":"北京"},{"id":2,"name":"上海"},{"id":3,"name":"廣州"},{"id":4,"name":"武漢"}] ? ? ? ? ? ? ? ? //1.獲取select ? ? ? ? ? ? ? ? var province = $("#province"); ? ? ? ? ? ? ? ? //2.遍歷json數(shù)組 ? ? ? ? ? ? ? ? $(data).each(function (){ ? ? ? ? ? ? ? ? ? ? //3.創(chuàng)建<option> ? ? ? ? ? ? ? ? ? ? var option = "<option name='" + this +"'>" + this.name + "</option>"; ? ? ? ? ? ? ? ? ? ? //4.調(diào)用select的append方法追加 ? ? ? ? ? ? ? ? ? ? province.append(option); ? ? ? ? ? ? ? ? }); ? ? ? ? ? ? }); ? ? ? ? }); ? ? </script> <body> ? ? <select id="province"> ? ? ? ? <option>---請(qǐng)選擇省份---</option> ? ? </select> </body> </html>
效果展示
第一次查詢時(shí)
此時(shí)可以看到redis沒(méi)有數(shù)據(jù),所以查詢了數(shù)據(jù)庫(kù)
第二次查詢
此時(shí)可以看到redis中已經(jīng)有緩存了,所以沒(méi)有查詢數(shù)據(jù)庫(kù)
注意
當(dāng)數(shù)據(jù)中的數(shù)據(jù)進(jìn)行增刪改時(shí),緩存的數(shù)據(jù)依舊不會(huì)改變,所以當(dāng)進(jìn)行增刪改操作后,應(yīng)該刪除redis中的緩存,然后在重新緩存,從而達(dá)到更新緩存的效果。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何操作Redis和zookeeper實(shí)現(xiàn)分布式鎖
這篇文章主要介紹了如何操作Redis和zookeeper實(shí)現(xiàn)分布式鎖的相關(guān)資料,需要的朋友可以參考下2017-07-07Redis通用命令介紹以及key的層級(jí)結(jié)構(gòu)講解
這篇文章主要介紹了Redis通用命令以及key的層級(jí)結(jié)構(gòu),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-12-12Redis實(shí)現(xiàn)UV統(tǒng)計(jì)的示例代碼
本文主要介紹了Redis實(shí)現(xiàn)UV統(tǒng)計(jì)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01基于Redis緩存數(shù)據(jù)常見的三種問(wèn)題及解決
這篇文章主要介紹了基于Redis緩存數(shù)據(jù)常見的三種問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06Go語(yǔ)言操作RediSearch進(jìn)行搜索方法示例詳解
這篇文章主要為大家介紹了Go語(yǔ)言操作RediSearch進(jìn)行搜索方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼
這篇文章主要介紹了Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02詳解Redis單線程架構(gòu)的優(yōu)勢(shì)與不足
很多人都遇到過(guò)這么一道面試題:Redis是單線程還是多線程?這個(gè)問(wèn)題既簡(jiǎn)單又復(fù)雜,說(shuō)他簡(jiǎn)單是因?yàn)榇蠖鄶?shù)人都知道Redis是單線程,說(shuō)復(fù)雜是因?yàn)檫@個(gè)答案其實(shí)并不準(zhǔn)確,本文就給大家講講Redis單線程架構(gòu)的優(yōu)勢(shì)與不足,需要的朋友可以參考下2024-02-02redis?zset實(shí)現(xiàn)滑動(dòng)窗口限流的代碼
這篇文章主要介紹了redis?zset實(shí)現(xiàn)滑動(dòng)窗口限流,滑動(dòng)窗口算法思想就是記錄一個(gè)滑動(dòng)的時(shí)間窗口內(nèi)的操作次數(shù),操作次數(shù)超過(guò)閾值則進(jìn)行限流,本文通過(guò)實(shí)例代碼給大家詳細(xì)介紹,需要的朋友參考下吧2022-03-03