java中redis增刪查以及清理緩存的案例
我就廢話不多說(shuō)了,大家還是直接看代碼吧~
Controller@ApiOperation(value = '獲取信息放入Redis中') @RequestMapping(value = '/getPropertyTakeLookShoppingDetailRedis',method = RequestMethod.POST) public JsonResult getPropertyTakeLookShoppingDetailRedis(@RequestBody PropertyTakeLookRedisParam param) throws Exception { log.info('PropertyTakeLookController.getPropertyTakeLookShoppingDetailRedis:' + param); JSONObject jsonObject = propertyTakeLookWriteService.getPropertyTakeLookShoppingDetailRedis(param); log.info('PropertyTakeLookController.getPropertyTakeLookSysInfo:' + jsonObject); return JsonResult.getResult(jsonObject); }Service
增刪查區(qū)分 讀緩存 = 0; 添加 =1;刪除 = 2 ; 清除相應(yīng)經(jīng)紀(jì)人清單緩存 = 3 ')
/** * 獲取信息放入Redis中 * @return * @throws Exception */ public JSONObject getPropertyTakeLookShoppingDetailRedis(PropertyTakeLookRedisParam param) throws Exception { String takeLookStr = 'DKQD'; checkArgument(StringUtils.isNotBlank(param.getTakeLookUserEmpNo()), '工號(hào)不能為空!'); checkArgument(param.getSelOrAddOrRemove() != null, '增刪查區(qū)分不能為空!'); String takeLookUserEmpNo = param.getTakeLookUserEmpNo(); JSONObject jsonObject; if(redisHandle.exists(takeLookUserEmpNo+takeLookStr) && param.getSelOrAddOrRemove() == 0){ jsonObject = JSONObject.parseObject(redisHandle.get(takeLookUserEmpNo+takeLookStr).toString()); } else if(param.getSelOrAddOrRemove() == 1 || param.getSelOrAddOrRemove() == 2){ Long[] effectiveIds = param.getPropertyEffectiveId(); PropertyTakeLookShoppingCartParam propertyTakeLookShoppingCartParam = new PropertyTakeLookShoppingCartParam(); BeanUtils.copyProperties(param,propertyTakeLookShoppingCartParam); propertyTakeLookShoppingCartParam.setPropertyEffectiveId(effectiveIds); //獲取信息 PageInfo<?> takeLookDetail = propertytakelookService.getPropertyTakeLookShoppingCartDetail(propertyTakeLookShoppingCartParam); System.out.print('參數(shù)查看' + JsonResult.getResult(takeLookDetail).toJson()); jsonObject = JSONObject.parseObject(JsonResult.getResult(takeLookDetail).toJson()); Object jsonArray = jsonObject.get('data'); redisHandle.set(takeLookUserEmpNo+takeLookStr,jsonArray); }else if (redisHandle.exists(takeLookUserEmpNo+takeLookStr) && param.getSelOrAddOrRemove() == 3){ //物理清除緩存 redisHandle.remove(takeLookUserEmpNo+takeLookStr); jsonObject = new JSONObject(); jsonObject.put('code',ErrorCode.SUCCESS.getCode()); jsonObject.put('msg',ErrorCode.SUCCESS.getMsg()); }else { jsonObject = new JSONObject(); jsonObject.put('code',ErrorCode.SUCCESS.getCode()); jsonObject.put('msg',ErrorCode.SUCCESS.getMsg()); } return jsonObject; }
補(bǔ)充:java按照關(guān)鍵字指定的key刪除redis(支持模糊刪除)
pom依賴(lài):<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.5.0</version> </dependency>代碼直接可用:
import org.testng.annotations.BeforeClass;import org.testng.annotations.Test;import redis.clients.jedis.Jedis;import java.util.HashMap;import java.util.Iterator;import java.util.List;import java.util.Map;public class TestRedis { private Jedis jedis; @BeforeClass public void setup() { //連接redis服務(wù)器,ip jedis = new Jedis('ip', 6379); //權(quán)限認(rèn)證 jedis.auth('123456'); } /** * 刪除數(shù)據(jù) * * * @param key:要?jiǎng)h除數(shù)據(jù)的key * @return:返回boolean值,表示是否刪除成功 */ public boolean delete(String key) { if (jedis.exists(key)) { if (jedis.del(key) == 1) { System.out.println('刪除數(shù)據(jù)成功'); return true; } else { System.out.println('刪除數(shù)據(jù)失敗'); return false; } } else { System.out.println(key + '不存在'); return false; } } @Test public void test() { delete('age'); }}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. ASP.NET MVC使用Boostrap實(shí)現(xiàn)產(chǎn)品展示、查詢(xún)、排序、分頁(yè)2. vue 動(dòng)態(tài)組件用法示例小結(jié)3. 基于Python模擬瀏覽器發(fā)送http請(qǐng)求4. 如何通過(guò)PHP實(shí)現(xiàn)Des加密算法代碼實(shí)例5. Spring基于advisor配置aop過(guò)程解析6. vue cli3.0打包上線靜態(tài)資源找不到路徑的解決操作7. 詳解ABP框架中的日志管理和設(shè)置管理的基本配置8. 解決idea中svn提交時(shí)performing vcs refresh時(shí)間很長(zhǎng)的問(wèn)題9. idea實(shí)現(xiàn)類(lèi)快捷生成接口方法示例10. 使用python 計(jì)算百分位數(shù)實(shí)現(xiàn)數(shù)據(jù)分箱代碼
