我就廢話不多說了,大家還是直接看代碼吧~
Controller
1
2
3
4
5
6
7
8
|
@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
增刪查區分 讀緩存 = 0; 添加 =1;刪除 = 2 ; 清除相應經紀人清單緩存 = 3 ")
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
/** * 獲取信息放入Redis中 * @return * @throws Exception */ public JSONObject getPropertyTakeLookShoppingDetailRedis(PropertyTakeLookRedisParam param) throws Exception { String takeLookStr = "DKQD" ; checkArgument(StringUtils.isNotBlank(param.getTakeLookUserEmpNo()), "工號不能為空!" ); checkArgument(param.getSelOrAddOrRemove() != null , "增刪查區分不能為空!" ); 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( "參數查看" + 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; } |
補充:java按照關鍵字指定的key刪除redis(支持模糊刪除)
pom依賴:
1
2
3
4
5
|
< dependency > < groupId >redis.clients</ groupId > < artifactId >jedis</ artifactId > < version >2.5.0</ version > </ dependency > |
代碼直接可用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
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服務器,ip jedis = new Jedis( "ip" , 6379 ); //權限認證 jedis.auth( "123456" ); } /** * 刪除數據 * * * @param key:要刪除數據的key * @return:返回boolean值,表示是否刪除成功 */ public boolean delete(String key) { if (jedis.exists(key)) { if (jedis.del(key) == 1 ) { System.out.println( "刪除數據成功" ); return true ; } else { System.out.println( "刪除數據失敗" ); return false ; } } else { System.out.println(key + "不存在" ); return false ; } } @Test public void test() { delete( "age" ); } } |
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。如有錯誤或未考慮完全的地方,望不吝賜教。
原文鏈接:https://blog.csdn.net/qq_40110781/article/details/88600984