欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識(shí)庫(kù) > Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼

Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼

熱門標(biāo)簽:魔獸2青云地圖標(biāo)注 北京400電話辦理收費(fèi)標(biāo)準(zhǔn) 十堰營(yíng)銷電銷機(jī)器人哪家便宜 日本中國(guó)地圖標(biāo)注 貴州電銷卡外呼系統(tǒng) 鄭州人工智能電銷機(jī)器人系統(tǒng) 超呼電話機(jī)器人 宿遷便宜外呼系統(tǒng)平臺(tái) 山東外呼銷售系統(tǒng)招商

目標(biāo)

利用Redis實(shí)現(xiàn)商城購(gòu)物車功能。

功能

根據(jù)用戶編號(hào)查詢購(gòu)物車列表,且各個(gè)商品需要跟在對(duì)應(yīng)的店鋪下;統(tǒng)計(jì)購(gòu)物車中的商品總數(shù);新增或刪減購(gòu)物車商品;增加或減少購(gòu)物車中的商品數(shù)量。


分析

Hash數(shù)據(jù)類型:值為多組映射,相當(dāng)于JAVA中的Map。適合存儲(chǔ)對(duì)象數(shù)據(jù)類型。因?yàn)橛脩鬒D作為唯一的身份標(biāo)識(shí),所以可以把模塊名稱+用戶ID作為Redis的鍵;商品ID作為商品的唯一標(biāo)識(shí),可以把店鋪編號(hào)+商品ID作為Hash元素的鍵,商品數(shù)量為元素的值。


代碼實(shí)現(xiàn)

控制層

package com.shoppingcart.controller;
 
import com.shoppingcart.service.ShoppingCartServer;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.util.List;
import java.util.Map;
 
/**
 * redis實(shí)現(xiàn)購(gòu)物車功能
 */
@RestController
@RequestMapping("/shoppingCart")
public class ShoppingCartController {
 @Resource
 private ShoppingCartServer shoppingCartServer;
 
 /**
  * http://localhost:8099/shoppingCart/addCommodity?userId=001shopId=1234560commodityId=001commodityNum=336
  * 添加商品
  * @return
  * @param: userId 用戶ID
  * @param: [{shopId:商鋪id,commodityId:商品id,commodityNum:商品數(shù)量},{shopId:商鋪id,commodityId:商品id,commodityNum:商品數(shù)量}]
  * 測(cè)試數(shù)據(jù):
  [
  {
  "shopId": 123,
  "commodityId": 145350,
  "commodityNum": 155.88
  },
  {
  "shopId": 123,
  "commodityId": 6754434,
  "commodityNum": 945.09
  },
  {
  "shopId": 123,
  "commodityId": 7452,
  "commodityNum": 2445.09
  },
  {
  "shopId": 3210,
  "commodityId": 98766,
  "commodityNum": 2345.09
  },
  {
  "shopId": 456,
  "commodityId": 2435640,
  "commodityNum": 11945.09
  }
  ]
  */
 @GetMapping("/addCommodity")
 public MapString, Object> addCommodity(
   @RequestParam(value = "userId", required = true) String userId,
   @RequestBody ListMapString, Object>> list
 ) {
  MapString, Object> map = shoppingCartServer.addCommodity(userId, list);
  return map;
 }
 
 /**
  * 購(gòu)物車列表
  * http://localhost:8099/shoppingCart/shoppingCartList?userId=001
  *
  * @param userId
  * @return 返回{店鋪ID:商品ID=商品數(shù)量}的map。
  */
 @GetMapping("/shoppingCartList")
 public MapObject, Object> shoppingCartList(
   @RequestParam(value = "userId", required = true) String userId,
   @RequestParam(value = "pageNo", defaultValue = "0") Long pageNo,
   @RequestParam(value = "pageSize", defaultValue = "10") Long pageSize
 ) {
  MapObject, Object> map = shoppingCartServer.shoppingCartList(userId, pageNo, pageSize);
  return map;
 }
 
 /**
  * http://localhost:8099/shoppingCart/updateNum?userId=001shopId=01comId=123456num=342
  * 修改商品數(shù)量。
  *
  * @param userId  用戶id
  * @param commodityId 商品id
  * @param commodityNum 商品數(shù)量
  * @return
  */
 @GetMapping("/updateNum")
 public MapString, Object> updateNum(
   @RequestParam(value = "userId", required = true) String userId,
   @RequestParam(value = "shopId", required = true) Long shopId,
   @RequestParam(value = "commodityId", required = true) Long commodityId,
   @RequestParam(value = "commodityNum", required = true) Double commodityNum
 ) {
  return shoppingCartServer.updateNum(userId, shopId, commodityId, commodityNum);
 }
 
 /**
  * http://localhost:8099/shoppingCart/delCom?userId=001shopId=01comId=123457
  * 刪除購(gòu)物車中的商品
  * @return
  * @param: userId 用戶id
  * @param: [{shopId:商鋪id,commodityId:商品id},{shopId:商鋪id,commodityId:商品id}]
  */
 @PostMapping("/delCommodity")
 public MapString, Object> delCommodity(
   @RequestParam(value = "userId", required = true) String userId,
   @RequestBody ListMapString, Object>> list
 ) {
  return shoppingCartServer.delCommodity(userId, list);
 }
}

業(yè)務(wù)層

package com.shoppingcart.service;
 
import java.util.List;
import java.util.Map;
 
public interface ShoppingCartServer {
 //購(gòu)物車列表
 public MapObject, Object> shoppingCartList(String userId,Long pageNo,Long pageSize);
 MapString,Object> updateNum(String userId,Long shopId, Long commodityId, Double commodityNum);
 MapString, Object> delCommodity(String userId, ListMapString , Object>> list);
 MapString, Object> addCommodity(String userId, ListMapString , Object>> list);
}
package com.shoppingcart.service.impl;
 
import com.shoppingcart.service.ShoppingCartServer;
import com.shoppingcart.utils.RedisService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
@Service
public class ShoppingCartServerImpl implements ShoppingCartServer {
 @Autowired
 private RedisService redisService;
 //購(gòu)物車鍵名前綴
 public static final String SHOPPING_CART = "shoppingCart:";
 //購(gòu)物車的元素鍵名前綴
 public static final String SHOP_ID = "shopId";
 
 //添加商品
 @Override
 public MapString, Object> addCommodity(String userId, ListMapString, Object>> list) {
  //記錄:list中有哪些商品在購(gòu)物車中已經(jīng)存在。
  ListString> existCommoditys = new ArrayList>();
  //todo 購(gòu)物車key
  String key = SHOPPING_CART + userId;
  for (int i = 0; i  list.size(); i++) {
   String commodityKey = SHOP_ID + list.get(i).get("shopId") + ":" + list.get(i).get("commodityId");
   //todo 添加商品
   boolean boo = redisService.hsetnx(key, commodityKey, Double.parseDouble(list.get(i).get("commodityNum") + ""));
   if (!boo) {
    existCommoditys.add(commodityKey);
   }
  }
  MapString, Object> m = new HashMapString, Object>() {
   {
    put("existCommoditys", existCommoditys);
    put("existCommoditysMsg", "這些商品在購(gòu)物車中已經(jīng)存在,重復(fù)數(shù)量:"+existCommoditys.size()+"。");
   }
  };
  MapString, Object> map = new HashMapString, Object>();
  map.put("data", m);
  map.put("code", 0);
  return map;
 }
 
 //購(gòu)物車列表
 @Override
 public MapObject, Object> shoppingCartList(String userId, Long pageNo, Long pageSize) {
  //返回{店鋪ID:商品ID=商品數(shù)量}的map。
  MapObject, Object> map = redisService.hmget(SHOPPING_CART + userId);
  return map;
 }
 
 //修改商品數(shù)量
 @Override
 public MapString, Object> updateNum(String userId, Long shopId, Long commodityId, Double commodityNum) {
  MapString, Object> map = new HashMapString, Object>();
  //todo 購(gòu)物車key
  String key = SHOPPING_CART + userId;
  //todo 商品key
  String commodityKey = SHOP_ID + shopId + ":" + commodityId;
  //修改購(gòu)物車的數(shù)量
  boolean boo = redisService.hset(key, commodityKey, commodityNum);
  MapString, Object> m = new HashMapString, Object>() {
   {
    put("key", key);
    put("commodityKey", commodityKey);
    put("commodityNum", commodityNum);
   }
  };
  map.put("data", m);
  map.put("msg", boo == true ? "修改購(gòu)物車商品數(shù)量成功。" : "修改購(gòu)物車商品數(shù)量失敗。");
  map.put("code", boo == true ? 0 : 1);
  return map;
 }
 
 //刪除商品
 @Override
 public MapString, Object> delCommodity(String userId, ListMapString, Object>> list) {
  MapString, Object> map = new HashMapString, Object>();
  String[] commodityIds = new String[list.size()];
  for (int i = 0; i  list.size(); i++) {
   //todo 商品key
   commodityIds[i] = SHOP_ID + list.get(i).get("shopId") + ":" + list.get(i).get("commodityId");
  }
  //todo 購(gòu)物車key
  String key = SHOPPING_CART + userId;
  //刪除商品的數(shù)量
  Long num = redisService.hdel(key, commodityIds);
  map.put("msg", "刪除購(gòu)物車的商品數(shù)量:" + num);
  map.put("code", 0);
  return map;
 }
}

 

工具類

package com.shoppingcart.utils;
 
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class DateUtils {
 // 日期轉(zhuǎn)字符串,返回指定的格式
 public static String dateToString(Date date, String dateFormat) {
  SimpleDateFormat sdf = new SimpleDateFormat(dateFormat);
  return sdf.format(date);
 }
}
package com.shoppingcart.utils;
 
import com.alibaba.fastjson.JSONObject;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.RedisZSetCommands;
import org.springframework.data.redis.connection.SortParameters;
import org.springframework.data.redis.core.DefaultTypedTuple;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import org.w3c.dom.ranges.Range;
 
import java.util.*;
import java.util.concurrent.TimeUnit;
import java.util.stream.Collectors;
 
@Service
public class RedisService {
 
 @Autowired
 private RedisTemplateString, Object> redisTemplate;
 
 // =============================common============================
 
 /**
  * 指定緩存失效時(shí)間
  *
  * @param key 鍵
  * @param time 時(shí)間(秒)
  * @return
  */
 public boolean expire(String key, long time) {
  try {
   if (time > 0) {
    redisTemplate.expire(key, time, TimeUnit.SECONDS);
   }
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 根據(jù)key 獲取過期時(shí)間
  *
  * @param key 鍵 不能為null
  * @return 時(shí)間(秒) 返回0代表為永久有效
  */
 public long getExpire(String key) {
  return redisTemplate.getExpire(key, TimeUnit.SECONDS);
 }
 
 /**
  * 判斷key是否存在
  *
  * @param key 鍵
  * @return true 存在 false不存在
  */
 public boolean hasKey(String key) {
  try {
   return redisTemplate.hasKey(key);
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 刪除緩存
  *
  * @param key 可以傳一個(gè)值 或多個(gè)
  */
 @SuppressWarnings("unchecked")
 public void del(String... key) {
  if (key != null  key.length > 0) {
   if (key.length == 1) {
    redisTemplate.delete(key[0]);
   } else {
    ListString> list = new ArrayList>(Arrays.asList(key));
    redisTemplate.delete(list);
   }
  }
 }
 
 /**
  * 刪除緩存
  *
  * @param keys 可以傳一個(gè)值 或多個(gè)
  */
 @SuppressWarnings("unchecked")
 public void del(Collection keys) {
  if (org.apache.commons.collections4.CollectionUtils.isNotEmpty(keys)) {
   redisTemplate.delete(keys);
  }
 }
 
 // ============================String=============================
 
 /**
  * 普通緩存獲取
  *
  * @param key 鍵
  * @return 值
  */
 public Object get(String key) {
  return key == null ? null : redisTemplate.opsForValue().get(key);
 }
 
 /**
  * 普通緩存放入
  *
  * @param key 鍵
  * @param value 值
  * @return true成功 false失敗
  */
 public boolean set(String key, Object value) {
  try {
   redisTemplate.opsForValue().set(key, value);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 普通緩存放入并設(shè)置時(shí)間
  *
  * @param key 鍵
  * @param value 值
  * @param time 時(shí)間(秒) time要大于0 如果time小于等于0 將設(shè)置無限期
  * @return true成功 false 失敗
  */
 public boolean set(String key, Object value, long time) {
  try {
   if (time > 0) {
    redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
   } else {
    set(key, value);
   }
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 遞增
  *
  * @param key 鍵
  * @param delta 要增加幾(大于0)
  * @return
  */
 public long incr(String key, long delta) {
  if (delta  0) {
   throw new RuntimeException("遞增因子必須大于0");
  }
  return redisTemplate.opsForValue().increment(key, delta);
 }
 
 /**
  * 遞減
  *
  * @param key 鍵
  * @param delta 要減少幾(小于0)
  * @return
  */
 public long decr(String key, long delta) {
  if (delta  0) {
   throw new RuntimeException("遞減因子必須大于0");
  }
  return redisTemplate.opsForValue().increment(key, -delta);
 }
 
 // ================================Hash=================================
 
 /**
  * HashGet
  *
  * @param key 鍵 不能為null
  * @param item 項(xiàng) 不能為null
  * @return 值
  */
 public Object hget(String key, String item) {
  return redisTemplate.opsForHash().get(key, item);
 }
 
 /**
  * 獲取hashKey對(duì)應(yīng)的所有鍵值
  *
  * @param key 鍵
  * @return 對(duì)應(yīng)的多個(gè)鍵值
  */
 public MapObject, Object> hmget(String key) {
  MapObject, Object> entries = redisTemplate.opsForHash().entries(key);
  return entries;
 }
 
 /**
  * HashSet
  *
  * @param key 鍵
  * @param map 對(duì)應(yīng)多個(gè)鍵值
  * @return true 成功 false 失敗
  */
 public boolean hmset(String key, MapString, Object> map) {
  try {
   redisTemplate.opsForHash().putAll(key, map);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * HashSet 并設(shè)置時(shí)間
  *
  * @param key 鍵
  * @param map 對(duì)應(yīng)多個(gè)鍵值
  * @param time 時(shí)間(秒)
  * @return true成功 false失敗
  */
 public boolean hmset(String key, MapString, Object> map, long time) {
  try {
   redisTemplate.opsForHash().putAll(key, map);
   if (time > 0) {
    expire(key, time);
   }
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 
 /**
  * 向一張hash表中放入數(shù)據(jù),如果存在就覆蓋原來的值。
  *
  * @param key 鍵
  * @param item 項(xiàng)
  * @param value 值
  * @return true 成功 false失敗
  */
 public boolean hset(String key, String item, Object value) {
  try {
   redisTemplate.opsForHash().put(key, item, value);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 向一張hash表中放入數(shù)據(jù),如果存在就覆蓋原來的值。
  *
  * @param key 鍵
  * @param item 項(xiàng)
  * @param value 值
  * @param time 時(shí)間(秒) 注意:如果已存在的hash表有時(shí)間,這里將會(huì)替換原有的時(shí)間
  * @return true 成功 false失敗
  */
 public boolean hset(String key, String item, Object value, long time) {
  try {
   redisTemplate.opsForHash().put(key, item, value);
   if (time > 0) {
    expire(key, time);
   }
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 刪除hash表中的值
  *
  * @param key 鍵 不能為null
  * @param item 項(xiàng) 可以使多個(gè) 不能為null
  *    返回被刪除的數(shù)量
  */
 public Long hdel(String key, Object... item) {
  return redisTemplate.opsForHash().delete(key, item);
 }
 
 /**
  * 刪除hash表中的值
  *
  * @param key 鍵 不能為null
  * @param items 項(xiàng) 可以使多個(gè) 不能為null
  */
 public void hdel(String key, Collection items) {
  redisTemplate.opsForHash().delete(key, items.toArray());
 }
 
 /**
  * 判斷hash表中是否有該項(xiàng)的值
  *
  * @param key 鍵 不能為null
  * @param item 項(xiàng) 不能為null
  * @return true 存在 false不存在
  */
 public boolean hHasKey(String key, String item) {
  return redisTemplate.opsForHash().hasKey(key, item);
 }
 
 /**
  * hash數(shù)據(jù)類型:給元素一個(gè)增量 如果不存在,就會(huì)創(chuàng)建一個(gè) 并把新增后的值返回
  *
  * @param key 鍵
  * @param item 項(xiàng)
  * @param delta 要增加幾(大于0)
  * @return
  */
 public double hincr(String key, String item, double delta) {
  return redisTemplate.opsForHash().increment(key, item, delta);
 }
 // ============================set=============================
 
 /**
  * 根據(jù)key獲取Set中的所有值
  *
  * @param key 鍵
  * @return
  */
 public SetObject> sGet(String key) {
  try {
   return redisTemplate.opsForSet().members(key);
  } catch (Exception e) {
   e.printStackTrace();
   return null;
  }
 }
 
 /**
  * 根據(jù)value從一個(gè)set中查詢,是否存在
  *
  * @param key 鍵
  * @param value 值
  * @return true 存在 false不存在
  */
 public boolean sHasKey(String key, Object value) {
  try {
   return redisTemplate.opsForSet().isMember(key, value);
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 將數(shù)據(jù)放入set緩存
  *
  * @param key 鍵
  * @param values 值 可以是多個(gè)
  * @return 成功個(gè)數(shù)
  */
 public long sSet(String key, Object... values) {
  try {
   return redisTemplate.opsForSet().add(key, values);
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 /**
  * 將數(shù)據(jù)放入set緩存
  *
  * @param key 鍵
  * @param values 值 可以是多個(gè)
  * @return 成功個(gè)數(shù)
  */
 public long sSet(String key, Collection values) {
  try {
   return redisTemplate.opsForSet().add(key, values.toArray());
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 /**
  * 將set數(shù)據(jù)放入緩存
  *
  * @param key 鍵
  * @param time 時(shí)間(秒)
  * @param values 值 可以是多個(gè)
  * @return 成功個(gè)數(shù)
  */
 public long sSetAndTime(String key, long time, Object... values) {
  try {
   Long count = redisTemplate.opsForSet().add(key, values);
   if (time > 0)
    expire(key, time);
   return count;
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 /**
  * 獲取set緩存的長(zhǎng)度
  *
  * @param key 鍵
  * @return
  */
 public long sGetSetSize(String key) {
  try {
   return redisTemplate.opsForSet().size(key);
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 /**
  * 移除值為value的
  *
  * @param key 鍵
  * @param values 值 可以是多個(gè)
  * @return 移除的個(gè)數(shù)
  */
 public long setRemove(String key, Object... values) {
  try {
   Long count = redisTemplate.opsForSet().remove(key, values);
   return count;
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 // ===============================list=================================
 
 /**
  * 獲取list緩存的內(nèi)容
  *
  * @param key 鍵
  * @param start 開始
  * @param end 結(jié)束 0 到 -1代表所有值
  * @return
  */
 public ListObject> lGet(String key, long start, long end) {
  try {
   return redisTemplate.opsForList().range(key, start, end);
  } catch (Exception e) {
   e.printStackTrace();
   return null;
  }
 }
 
 /**
  * 獲取list緩存的長(zhǎng)度
  *
  * @param key 鍵
  * @return
  */
 public long lGetListSize(String key) {
  try {
   return redisTemplate.opsForList().size(key);
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 
 /**
  * 通過索引 獲取list中的值
  *
  * @param key 鍵
  * @param index 索引 index>=0時(shí), 0 表頭,1 第二個(gè)元素,依次類推;index0時(shí),-1,表尾,-2倒數(shù)第二個(gè)元素,依次類推
  * @return
  */
 public Object lGetIndex(String key, long index) {
  try {
   return redisTemplate.opsForList().index(key, index);
  } catch (Exception e) {
   e.printStackTrace();
   return null;
  }
 }
 
 /**
  * 將list放入緩存
  *
  * @param key 鍵
  * @param value 值
  * @return
  */
 public boolean lSet(String key, Object value) {
  try {
   redisTemplate.opsForList().rightPush(key, value);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 將list放入緩存
  *
  * @param key 鍵
  * @param value 值
  * @param time 時(shí)間(秒)
  * @return
  */
 public boolean lSet(String key, Object value, long time) {
  try {
   redisTemplate.opsForList().rightPush(key, value);
   if (time > 0)
    expire(key, time);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 將list放入緩存
  *
  * @param key 鍵
  * @param value 值
  * @return
  */
 public boolean lSet(String key, ListObject> value) {
  try {
   redisTemplate.opsForList().rightPushAll(key, value);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 將list放入緩存
  *
  * @param key 鍵
  * @param value 值
  * @param time 時(shí)間(秒)
  * @return
  */
 public boolean lSet(String key, ListObject> value, long time) {
  try {
   redisTemplate.opsForList().rightPushAll(key, value);
   if (time > 0)
    expire(key, time);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 根據(jù)索引修改list中的某條數(shù)據(jù)
  *
  * @param key 鍵
  * @param index 索引
  * @param value 值
  * @return
  */
 public boolean lUpdateIndex(String key, long index, Object value) {
  try {
   redisTemplate.opsForList().set(key, index, value);
   return true;
  } catch (Exception e) {
   e.printStackTrace();
   return false;
  }
 }
 
 /**
  * 移除N個(gè)值為value
  *
  * @param key 鍵
  * @param count 移除多少個(gè)
  * @param value 值
  * @return 移除的個(gè)數(shù)
  */
 public long lRemove(String key, long count, Object value) {
  try {
   Long remove = redisTemplate.opsForList().remove(key, count, value);
   return remove;
  } catch (Exception e) {
   e.printStackTrace();
   return 0;
  }
 }
 // ===============================Zset=================================
 
 /**
  * 給key鍵的value增加value分?jǐn)?shù),沒有則會(huì)創(chuàng)建。
  *
  * @param key 鍵
  * @param value 值
  * @param score 分?jǐn)?shù)
  */
 public Double incrementScore(String key, String value, double score) {
  //Boolean add = redisTemplate.boundZSetOps(key).add(value, score);
  Double add = redisTemplate.boundZSetOps(key).incrementScore(value, score);
  return add;
 }
 
 /**
  * 獲得指定Zset元素的分?jǐn)?shù)
  *
  * @param key
  * @param value
  * @return
  */
 public Double score(String key, String value) {
  Double score = redisTemplate.boundZSetOps(key).score(value);
  return score;
 }
 
 /**
  * 升序查詢key集合內(nèi)[endTop,startTop]如果是負(fù)數(shù)表示倒數(shù)
  * endTop=-1,startTop=0表示獲取所有數(shù)據(jù)。
  *
  * @param key
  * @param startPage
  * @param endPage
  */
 public SetZSetOperations.TypedTupleObject>> rangeWithScores(String key, int startPage, int endPage) {
  SetZSetOperations.TypedTupleObject>> set = redisTemplate.boundZSetOps(key).rangeWithScores(startPage, endPage);
  return set;
 }
 
 /**
  * 降序查詢key集合內(nèi)[endTop,startTop],如果是負(fù)數(shù)表示倒數(shù)
  * endTop=-1,startTop=0表示獲取所有數(shù)據(jù)。
  *
  * @param key
  * @param startPage
  * @param endPage
  */
 public SetZSetOperations.TypedTupleObject>> reverseRangeWithScores(String key, int startPage, int endPage) {
  SetZSetOperations.TypedTupleObject>> set = redisTemplate.boundZSetOps(key).reverseRangeWithScores(startPage, endPage);
  return set;
 }
 
 /**
  * 批量新增數(shù)據(jù)
  *
  * @param key
  * @param set
  * @return
  */
 public Long zsetAdd(String key, Set set) {
  Long add = redisTemplate.boundZSetOps(key).add(set);
  return add;
 }
 
 /**
  * 刪除指定鍵的指定下標(biāo)范圍數(shù)據(jù)
  *
  * @param key
  * @param startPage
  * @param endPage
  */
 public Long zsetRemoveRange(String key, int startPage, int endPage) {
  Long l = redisTemplate.boundZSetOps(key).removeRange(startPage, endPage);
  return l;
 }
 /**
  * 刪除指定鍵的指定值
  *
  * @param key
  * @param value
  */
 public Long zsetRemove(String key, String value) {
  Long remove = redisTemplate.boundZSetOps(key).remove(value);
  return remove;
 }
}

到此這篇關(guān)于Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼的文章就介紹到這了,更多相關(guān)Redis商城購(gòu)物車內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • java redis 實(shí)現(xiàn)簡(jiǎn)單的用戶簽到功能
  • 使用redis的increment()方法實(shí)現(xiàn)計(jì)數(shù)器功能案例
  • Java使用Redis實(shí)現(xiàn)秒殺功能
  • 多個(gè)SpringBoot項(xiàng)目采用redis實(shí)現(xiàn)Session共享功能
  • 使用Redis實(shí)現(xiàn)微信步數(shù)排行榜功能
  • 基于Redis實(shí)現(xiàn)抽獎(jiǎng)功能及問題小結(jié)

標(biāo)簽:北京 江蘇 吉安 楊凌 果洛 臺(tái)州 大慶 朝陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  Redis,實(shí)戰(zhàn),之,商城,購(gòu)物車,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于Redis實(shí)戰(zhàn)之商城購(gòu)物車功能的實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    久久尤物电影视频在线观看| 国产一区二区三区免费在线观看 | 日本最新不卡在线| 佐山爱在线视频| 五月天丁香激情| 国产精品美女一区二区三区| 国产精品一二三在| 91社区视频在线观看| 久久亚洲二区三区| 黄色成人免费在线| 日本成人免费在线观看 | 一区二区不卡免费视频| 91精品国产福利在线观看| 亚洲va韩国va欧美va精品| 成人一区二区三区仙踪林| 欧美日韩一卡二卡| 亚洲一区日韩精品中文字幕| 9191在线视频| 在线电影院国产精品| 日本v片在线高清不卡在线观看| 亚洲天堂2024| 日韩久久久久久| 久久99日本精品| 999福利视频| 国产精品久久久久久户外露出| 成人综合婷婷国产精品久久 | 另类小说一区二区三区| 韩国女同性做爰三级| 久久精品夜夜夜夜久久| 国产精品18久久久久久久久久久久| 在线观看天堂av| 亚洲欧美怡红院| 色婷婷狠狠18禁久久| 在线不卡中文字幕| 另类小说图片综合网| 天堂av免费在线| 亚洲日本丝袜连裤袜办公室| 国产麻豆剧传媒精品国产| 在线综合亚洲欧美在线视频| 另类综合日韩欧美亚洲| 欧美视频www| 亚洲香肠在线观看| 免费黄色在线视频| 国产精品免费久久久久| 美女又黄又免费的视频| 欧美tk丨vk视频| 粉嫩嫩av羞羞动漫久久久| 69久久精品无码一区二区| 91麻豆精品国产91久久久 | 欧美福利视频一区| 麻豆成人91精品二区三区| 欧美精品久久久久久久久46p| 亚洲最大成人综合| av网站免费在线看| 亚洲天堂久久久久久久| free性中国hd国语露脸| 国产精品久久久久影院老司 | 9人人澡人人爽人人精品| 6080亚洲精品一区二区| 国产一区二区伦理片| 欧美在线free| 激情深爱一区二区| 欧美中文一区二区三区| 蜜桃在线一区二区三区| 一本色道a无线码一区v| 秋霞电影网一区二区| 色婷婷av久久久久久久| 六月丁香婷婷色狠狠久久| 欧美中文字幕亚洲一区二区va在线 | 精品国产乱码久久久久久夜甘婷婷 | 一区二区三区在线免费视频| 白白色免费视频| 亚洲综合色噜噜狠狠| 少妇一级黄色片| 午夜久久电影网| 国产高潮国产高潮久久久91| 日本女人一区二区三区| 色综合色狠狠天天综合色| 亚洲美女视频一区| 国产精品成人在线视频| 亚洲va韩国va欧美va| wwwav国产| 久久成人18免费观看| 欧美性xxxxx极品少妇| 国产精品影视在线观看| 欧美一卡二卡在线| 黄色片子免费看| 国产欧美一区二区在线观看| 精品一区二区视频在线观看| 亚洲欧洲制服丝袜| 情侣偷拍对白清晰饥渴难耐| 亚洲精品久久久蜜桃| 一二三四在线观看视频| 视频一区欧美精品| 在线亚洲免费视频| 国产不卡视频一区二区三区| 日韩精品资源二区在线| 少妇极品熟妇人妻无码| 成人免费视频在线观看| 亚洲综合图片一区| 久久国产精品第一页| 91精品国产综合久久精品| 91麻豆高清视频| 中文字幕亚洲在| 中文字幕美女视频| 精品综合久久久久久8888| 91精品久久久久久久99蜜桃| 中文字幕久久久久久久| 1000精品久久久久久久久| 99热这里只有精品4| 精品一区二区久久久| 欧美成人一区二区三区| 国产精品久久AV无码| 亚洲一区二区中文在线| 欧美在线高清视频| 99国产精品久久久久久久久久| 欧美激情资源网| 美国美女黄色片| 精品制服美女久久| 精品免费国产一区二区三区四区| 在线黄色免费网站| 天天亚洲美女在线视频| 欧美高清视频www夜色资源网| 国产精品果冻传媒| 亚洲电影视频在线| 欧美日韩在线三区| 18禁一区二区三区| 五月婷婷久久丁香| 欧美一区二区三区在线| 国产精品无码网站| 蜜桃精品视频在线观看| 精品美女一区二区三区| 中文字幕成人动漫| 国产在线视频精品一区| 国产网站一区二区三区| 永久av免费网站| 成人综合在线视频| 亚洲欧美日韩国产一区二区三区| 免费在线观看h片| 99久久99久久综合| 亚洲自拍与偷拍| 91麻豆精品国产| 久久精品一区二区免费播放| 久久精品国产精品青草| 久久久久国产一区二区三区四区 | 国产亚洲一本大道中文在线| av片在线免费看| 成人性视频网站| 亚洲激情男女视频| 欧美美女直播网站| 丰满少妇一区二区| 国产成人av自拍| 一区二区三区日韩欧美| 欧美高清精品3d| 国产美女永久免费无遮挡| 国产精品99久久久久久宅男| 亚洲视频在线一区二区| 欧美日本韩国一区二区三区视频| 鲁大师私人影院在线观看| 精品一区二区三区久久| 国产精品久久久久久久久晋中 | 成a人片亚洲日本久久| 一区二区三区在线播| 欧美一级午夜免费电影| 国产毛片欧美毛片久久久| 成人aaaa免费全部观看| 亚洲va欧美va人人爽| 久久蜜桃av一区精品变态类天堂| h色网站在线观看| 中国xxxx性xxxx产国| 久久99九九99精品| 日韩一区中文字幕| 欧美一区二区私人影院日本| 成人免费视频入口| 欧美xxxx日本和非洲| 久久疯狂做爰流白浆xx| 成人免费在线视频观看| 日韩一区二区视频| 中日韩一级黄色片| 高清中文字幕mv的电影| 国产乱对白刺激视频不卡| 亚洲精品日日夜夜| 精品毛片乱码1区2区3区| 波多野结衣不卡视频| av直播在线观看| 99vv1com这只有精品| 麻豆久久久久久| 亚洲精品国产一区二区精华液 | 懂色av中文一区二区三区| 一区二区三区免费看视频| 精品久久国产97色综合| 在线观看91精品国产入口| 亚洲av毛片基地| 天堂va欧美va亚洲va老司机| 国产精品一级片| 日韩不卡一区二区三区| 综合激情成人伊人| 精品福利视频一区二区三区| 欧美日韩综合一区| 天天爽天天爽天天爽|