精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Java架構之Redis系列:通過文章點贊排名案例學習Sortedset命令

開發 后端 Redis
這一篇文章將講述Redis中的sortedset類型命令,同樣也是通過demo來講述,其他部分這里就不在贅述了。

 前言

這一篇文章將講述Redis中的sortedset類型命令,同樣也是通過demo來講述,其他部分這里就不在贅述了。

案例

demo功能是文章點贊排名等等,整個demo的大致頁面如下。

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

準備工作

首先定義一個存儲文章的key

  1. private static final String ZSET_KEY = "articleList"

redis操作對象

  1. private RedisTemplate redisTemplate; 
  2.  
  3. //string 命令操作對象 
  4.  
  5. private ValueOperations valueOperations; 
  6.  
  7. //zset 命令操作對象 
  8.  
  9. private ZSetOperations zSetOperations; 

sortedset在Redis中的結構可以看下圖(圖片來源于Redis in Action)。

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

列表查詢

  1. @RequestMapping(value = "/getList/{sortType}", method = RequestMethod.GET) 
  2.  
  3. public Set getList(@PathVariable String sortType) { 
  4.  
  5. //如果沒有數據,則添加10條數據 
  6.  
  7. if (zSetOperations.size(ZSET_KEY) == 0){ 
  8.  
  9. for (int i = 1; i <= 10; i++) { 
  10.  
  11. zSetOperations.add(ZSET_KEY,"文章:"+i, (int)(Math.random()*10+i)); 
  12.  
  13.  
  14.  
  15. //ASC根據分數從小到大排序,DESC反之 
  16.  
  17. if ("ASC".equals(sortType)){ 
  18.  
  19. return zSetOperations.rangeWithScores(ZSET_KEY, 0, -1); 
  20.  
  21. else { 
  22.  
  23. return zSetOperations.reverseRangeWithScores(ZSET_KEY, 0, -1); 
  24.  
  25.  

這里為了省去一個個添加數據的麻煩,就在獲取列表數據中加了個判斷。當文章數據為0時,默認添加10條數據,設置隨機score加上所在的索引。

然后根據url中的參數sortType來決定返回的數據是按照分數升序還是降序排序。功能效果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

命令介紹

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

贊或踩

java代碼如下

  1. @RequestMapping(value = "/star", method = RequestMethod.POST) 
  2.  
  3. public boolean starOrUnStar(String member, String type) { 
  4.  
  5. if ("UP".equals(type)){ 
  6.  
  7. zSetOperations.incrementScore(ZSET_KEY, member, 1); 
  8.  
  9. else { 
  10.  
  11. zSetOperations.incrementScore(ZSET_KEY, member, -1); 
  12.  
  13.  
  14. return true
  15.  

根據type決定是否加減分數,當type為UP時表示贊,為其他(DOWN)時表示踩。功能效果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

命令介紹

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

升降序排名

java代碼如下

  1. @RequestMapping(value = "/rank/{type}/{member}", method = RequestMethod.GET) 
  2.  
  3. public Long rank(@PathVariable String member, @PathVariable String type) { 
  4.  
  5. Long rank = null
  6.  
  7. if ("ASC".equals(type)){ 
  8.  
  9. rank = zSetOperations.rank(ZSET_KEY, member); 
  10.  
  11. else { 
  12.  
  13. rank = zSetOperations.reverseRank(ZSET_KEY, member); 
  14.  
  15.  
  16. return rank; 
  17.  

根據type決定是升序排名還是降序排名,如果是ASC則調用rank方法獲取升序排名,其他則調用reverseRank獲取降序排名。與下方redis命令類似

  1. ZRANK articleList "文章1" 
  2.  
  3. ZREVRANK articleList "文章1" 

頁面效果圖如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

命令介紹

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

其他命令

獲取屬性

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

ZCARD命令

返回key的有序集元素個數。

ZCARD key

返回值:key存在的時候,返回有序集的元素個數,否則返回0。

redis客戶端執行的命令如下

  1. zadd zCardKey 1 one 
  2. zcard zCardKey 

下面是java代碼

  1. @Test 
  2.  
  3. public void zCard() { 
  4.  
  5. jedis.zadd("zCardKey",1, "one"); 
  6.  
  7. jedis.zadd("zCardKey",2, "two"); 
  8.  
  9. System.out.println(jedis.zcard("zCardKey")); 
  10.  
  11. System.out.println(zSetOperations.size("zCardKey")); 
  12.  

ZCOUNT命令

返回有序集key中,score值在min和max之間(默認包括score值等于min或max)的成員數量。

ZCOUNT key min max

返回值:指定分數范圍的元素個數。

redis客戶端執行的命令如下

  1. zadd zCountKey 1 one 2 two 3 three 4 four 
  2. zcount zCountKey 2 3 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zCount() { 
  4.  
  5. jedis.zadd("zCountKey",1, "one"); 
  6.  
  7. jedis.zadd("zCountKey",2, "two"); 
  8.  
  9. jedis.zadd("zCountKey",3, "three"); 
  10.  
  11. jedis.zadd("zCountKey",4, "four"); 
  12.  
  13. System.out.println(jedis.zcount("zCountKey",2, 3)); 
  14.  
  15. System.out.println(zSetOperations.count("zCountKey",2, 3)); 
  16.  

ZLEXCOUNT命令

計算有序集合中指定成員之間的成員數量(按成員字典正序排序),可以使用 - 和 + 表示score最小值和最大值

ZLEXCOUNT key min max

redis客戶端執行的命令如下

  1. ZADD zLexCountKey 2 "b" 1 "a" 3 "c" 5 "e" 4 "d" 
  2.  
  3. ZLEXCOUNT zLexCountKey - + 
  4.  
  5. ZLEXCOUNT zLexCountKey [b [d 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zLexCount() { 
  4.  
  5. zSetOperations.add("zLexCountKey""b", 2); 
  6.  
  7. zSetOperations.add("zLexCountKey""a", 1); 
  8.  
  9. zSetOperations.add("zLexCountKey""c", 3); 
  10.  
  11. zSetOperations.add("zLexCountKey""e", 5); 
  12.  
  13. zSetOperations.add("zLexCountKey""d", 4); 
  14.  
  15. System.out.println(jedis.zlexcount("zLexCountKey""-""+")); 
  16.  
  17. System.out.println(jedis.zlexcount("zLexCountKey""[b""[d")); 
  18.  

ZSCORE命令

返回有序集key中,成員member的score值。

ZSCORE key member

返回值:成員member的score值

redis客戶端執行的命令如下

  1. zadd zScoreKey 1 one 
  2.  
  3. ZSCORE zScoreKey one 

下面是java代碼

  1. @Test 
  2.  
  3. public void zScore() { 
  4.  
  5. jedis.zadd("zScoreKey",1, "one"); 
  6.  
  7. System.out.println(jedis.zscore("zScoreKey""one")); 
  8.  
  9. System.out.println(zSetOperations.score("zScoreKey""one")); 
  10.  

獲取成員

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

ZRANGEBYLEX命令

返回指定成員區間內的成員,按成員字典正序排序。

https://redis.io/commands/zrangebylex

ZRANGEBYLEX key min max [LIMIT offset count]

返回值:指定成員范圍的元素列表。

redis客戶端執行的命令如下

  1. ZADD zRangeByLexKey 0 ba 0 a 0 ab 0 aa 0 b 
  2.  
  3. ZRANGEBYLEX zRangeByLexKey - + 
  4.  
  5. ZRANGEBYLEX zRangeByLexKey [aa (ba 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zRangeByLex() { 
  4.  
  5. zSetOperations.add("zRangeByLexKey""ba", 0); 
  6.  
  7. zSetOperations.add("zRangeByLexKey""a", 0); 
  8.  
  9. zSetOperations.add("zRangeByLexKey""ab", 0); 
  10.  
  11. zSetOperations.add("zRangeByLexKey""aa", 0); 
  12.  
  13. zSetOperations.add("zRangeByLexKey""b", 0); 
  14.  
  15. System.out.println(jedis.zrangeByLex("zRangeByLexKey""-""+")); 
  16.  
  17. RedisZSetCommands.Range range = new RedisZSetCommands.Range(); 
  18.  
  19. range.gte("aa"); 
  20.  
  21. range.lt("ba"); 
  22.  
  23. System.out.println(zSetOperations.rangeByLex("zRangeByLexKey",range)); 
  24.  

ZRANGEBYSCORE命令

獲取score在范圍之內的數據。min和max可以是-inf和+inf

ZRANGEBYSCORE key min max [WITHSCORES]``[LIMIT offset count]

redis客戶端執行的命令如下

  1. ZADD zRangeByScoreKey 1 ba 2 a 3 ab 4 aa 5 b 
  2.  
  3. ZRANGEBYSCORE zRangeByScoreKey -inf +inf 
  4.  
  5. ZRANGEBYSCORE zRangeByScoreKey 2 4 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zRangeByScore() { 
  4.  
  5. zSetOperations.add("zRangeByScoreKey""ba", 1); 
  6.  
  7. zSetOperations.add("zRangeByScoreKey""a", 2); 
  8.  
  9. zSetOperations.add("zRangeByScoreKey""ab", 3); 
  10.  
  11. zSetOperations.add("zRangeByScoreKey""aa", 4); 
  12.  
  13. zSetOperations.add("zRangeByScoreKey""b", 5); 
  14.  
  15. System.out.println(jedis.zrangeByScore("zRangeByScoreKey""-inf""+inf")); 
  16.  
  17. RedisZSetCommands.Range range = new RedisZSetCommands.Range(); 
  18.  
  19. System.out.println(zSetOperations.rangeByScore("zRangeByScoreKey", 2, 4)); 
  20.  

移除相關命令

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

ZREM命令

ZREM key member [member ...]

返回值:有序集合中刪除的成員個數

redis客戶端執行的命令如下

  1. ZADD zRemKey 1 "one" 2 "two" 3 "three" 
  2.  
  3. ZREM zRemKey one 
  4.  
  5. ZRANGE zRemKey 0 -1 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zRem() { 
  4.  
  5. zSetOperations.add("zRemKey""one", 1); 
  6.  
  7. zSetOperations.add("zRemKey""two", 2); 
  8.  
  9. zSetOperations.add("zRemKey""three", 3); 
  10.  
  11. //jedis.zrem("zRemKey""one"); 
  12.  
  13. zSetOperations.remove("zRemKey""one"); 
  14.  
  15. System.out.println(zSetOperations.range("zRemKey", 0 , -1)); 
  16.  

交并集

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

ZINTERSTORE命令

計算給定的numkeys個有序集合的交集,并且把結果放到destination中。

在給定要計算的key和其它參數之前,必須先給定key個數(numberkeys)。

默認情況下,結果中一個元素的分數是有序集合中該元素分數之和,前提是該元素在這些有序集合中都存在。因為交集要求其成員必須是給定的每個有序集合中的成員,結果集中的每個元素的分數和輸入的有序集合個數相等。

對于WEIGHTS和AGGREGATE參數的描述,參見命令ZUNIONSTORE。

如果destination存在,就把它覆蓋。

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

返回值:結果有序集合destination中元素個數。

redis客戶端執行的命令如下

  1. ZADD zInterStoreKey1 1 "one" 2 "two" 
  2.  
  3. ZADD zInterStoreKey2 1 "one" 2 "two" 3 "three" 
  4.  
  5. ZINTERSTORE zInterStoreSumResult 2 zInterStoreKey1 zInterStoreKey2 WEIGHTS 2 3 
  6.  
  7. ZRANGE zInterStoreSumResult 0 -1 WITHSCORES 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zInterStore() { 
  4.  
  5. zSetOperations.add("zInterStoreKey1""one", 1); 
  6.  
  7. zSetOperations.add("zInterStoreKey1""two", 2); 
  8.  
  9. zSetOperations.add("zInterStoreKey2""one", 1); 
  10.  
  11. zSetOperations.add("zInterStoreKey2""two", 2); 
  12.  
  13. zSetOperations.add("zInterStoreKey2""three", 3); 
  14.  
  15. ZParams zParams = new ZParams(); 
  16.  
  17. zParams.weightsByDouble(2, 3); 
  18.  
  19. zParams.aggregate(ZParams.Aggregate.SUM); 
  20.  
  21. jedis.zinterstore("zInterStoreSumResult", zParams, "zInterStoreKey1""zInterStoreKey2"); 
  22.  
  23. printTuple("zInterStoreSumResult", jedis.zrangeWithScores("zInterStoreSumResult", 0, -1)); 
  24.  

ZUNIONSTORE命令

計算給定的numkeys個有序集合的并集,并且把結果放到destination中。

WEIGHTS參數相當于權重,默認就是1,可以給不同的key設置不同的權重

AGGREGATE參數默認使用的參數SUM,還可以選擇MIN或者MAX。這個參數決定結果集的score是取給定集合中的相加值、最小值還是最大值

ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...] ] [AGGREGATE SUM|MIN|MAX]

redis客戶端執行的命令如下

  1. ZADD zUnionStoreKey1 1 "one" 2 "two" 
  2.  
  3. ZADD zUnionStoreKey2 1 "one" 2 "two" 3 "three" 
  4.  
  5. ZUNIONSTORE zUnionStoreSumResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 
  6.  
  7. ZUNIONSTORE zUnionStoreMinResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MIN 
  8.  
  9. ZUNIONSTORE zUnionStoreMaxResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MAX 
  10.  
  11.  
  12. ZRANGE zUnionStoreSumResult 0 -1 WITHSCORES 
  13.  
  14. ZRANGE zUnionStoreMinResult 0 -1 WITHSCORES 
  15.  
  16. ZRANGE zUnionStoreMaxResult 0 -1 WITHSCORES 

執行結果如下

Java架構之redis系列:通過文章點贊排名案例學習sortedset命令

下面是java代碼

  1. @Test 
  2.  
  3. public void zUnionStore() { 
  4.  
  5. zSetOperations.add("zUnionStoreKey1""one", 1); 
  6.  
  7. zSetOperations.add("zUnionStoreKey1""two", 2); 
  8.  
  9. zSetOperations.add("zUnionStoreKey2""one", 1); 
  10.  
  11. zSetOperations.add("zUnionStoreKey2""two", 2); 
  12.  
  13. zSetOperations.add("zUnionStoreKey2""three", 3); 
  14.  
  15. ZParams zParams = new ZParams(); 
  16.  
  17. zParams.weightsByDouble(2, 3); 
  18.  
  19. zParams.aggregate(ZParams.Aggregate.SUM); 
  20.  
  21. jedis.zunionstore("zUnionStoreSumResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  22.  
  23. //求最小值 
  24.  
  25. zParams.aggregate(ZParams.Aggregate.MIN); 
  26.  
  27. jedis.zunionstore("zUnionStoreMinResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  28.  
  29. //求最大值 
  30.  
  31. zParams.aggregate(ZParams.Aggregate.MAX); 
  32.  
  33. jedis.zunionstore("zUnionStoreMaxResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  34.  
  35. //spring 
  36.  
  37. zSetOperations.unionAndStore("zUnionStoreKey1""zUnionStoreKey2""zUnionStoreResult"); 
  38.  
  39. printTuple("zUnionStoreSumResult", jedis.zrangeWithScores("zUnionStoreSumResult", 0, -1)); 
  40.  
  41. printTuple("zUnionStoreMinResult", jedis.zrangeWithScores("zUnionStoreMinResult", 0, -1)); 
  42.  
  43. printTuple("zUnionStoreMaxResult", jedis.zrangeWithScores("zUnionStoreMaxResult", 0, -1)); 
  44.  
  45. printTuple("zUnionStoreResult", jedis.zrangeWithScores("zUnionStoreResult", 0, -1)); 
  46.  
責任編輯:華軒 來源: 今日頭條
相關推薦

2020-01-10 15:15:53

Redis點贊數據庫

2020-12-03 11:00:29

Spring ClouRedis數據庫

2020-05-11 17:00:30

點贊MySQLRedis

2018-02-24 11:11:02

Linux命令 文件系統

2009-09-22 13:10:22

ibmdwSOA

2015-07-17 10:41:59

點贊按鈕

2021-08-10 15:37:34

鴻蒙HarmonyOS應用

2020-12-14 11:26:25

接口測試python

2018-01-02 11:55:59

Linux文件系統FSCK命令

2017-06-07 14:58:39

Redis源碼學習Redis事務

2025-11-17 09:06:13

架構計數業務數據庫

2020-12-30 07:26:20

RedisSortedSet內存包

2012-08-22 10:18:03

PHP

2020-12-08 12:24:55

接口測試Interface

2011-06-02 10:28:18

2014-08-01 13:40:50

R語言

2016-09-18 19:07:33

Java值傳遞引用傳遞

2020-12-29 10:16:24

接口測試flaskmock

2016-09-21 14:17:11

JUnit架構API
點贊
收藏

51CTO技術棧公眾號

日韩一二三区| 在线国产情侣| 午夜一区不卡| 色悠悠国产精品| 一级片免费在线观看视频| 自拍亚洲图区| 久久久久久电影| 成人激情在线观看| 午夜精品三级久久久有码| 成人三级视频| 精品国产亚洲在线| 亚洲成人av免费看| 99re6在线精品视频免费播放| 国产性色一区二区| 97久久天天综合色天天综合色hd| 天堂中文字幕在线观看| 91成人网在线观看| 亚洲片在线资源| 男人添女人荫蒂国产| 123成人网| 午夜视频在线观看一区二区| 亚洲在线播放电影| 水莓100在线视频| 国产综合久久久久久久久久久久| 91sa在线看| 欧美成人免费观看视频| 成人精品电影| 国产视频欧美视频| 理论片大全免费理伦片| 小说区图片区亚洲| 色婷婷综合久久久中文字幕| 国产精品久久久久久久乖乖| 1pondo在线播放免费| 91小视频在线免费看| 肥熟一91porny丨九色丨| 91无套直看片红桃| 日本欧美一区二区| 日本老师69xxx| 久久精品这里有| 欧美精品播放| 欧美成人免费在线视频| 最新日韩免费视频| 日本午夜一区| 一区二区在线视频播放| 中文字幕免费看| 欧美人与动xxxxz0oz| 亚洲福利视频二区| 免费观看污网站| 深夜福利一区二区三区| 91精品国产色综合久久不卡电影 | 欧美a在线看| 国产人成一区二区三区影院| 蜜桃网站成人| 欧美日韩影视| 久久久久久久久岛国免费| 久久综合九色99| 天天在线女人的天堂视频| 波多野结衣一区二区三区| 国产一区二区三区免费不卡| 人人妻人人澡人人爽久久av| 不卡一卡二卡三乱码免费网站| 国产91视觉| 少妇一级淫片免费看| www.欧美日韩国产在线| 久久精品日产第一区二区三区精品版 | 九七久久人人| 亚洲日本在线天堂| 国产盗摄视频在线观看| 亚洲第一图区| 午夜精品久久久久久久蜜桃app| 欧美精品自拍视频| 日本在线高清| 欧美性高清videossexo| 亚洲第一天堂久久| 日韩精品一区二区三区中文字幕| 日韩美女主播在线视频一区二区三区| 国产成人av免费观看| 哺乳一区二区三区中文视频| 亚洲精品久久久久久下一站| www.色天使| 久久影院一区| 欧美夫妻性生活xx| 亚洲欧美自拍视频| 久久精品国产久精国产爱| 91一区二区三区| 完全免费av在线播放| 久久无码高潮喷水| 欧美爱爱视频| 欧美精品一区二| aaaaa级少妇高潮大片免费看| 国产亚洲一卡2卡3卡4卡新区| 色综合伊人色综合网站| 精品肉丝脚一区二区三区| 欧美一级网站| 亚洲精品女av网站| 欧美18xxxxx| 亚洲丝袜精品丝袜在线| 北条麻妃在线视频观看| 久久免费资源| 日韩精品视频观看| 成人高潮免费视频| 国产欧美另类| 亚洲综合最新在线| 国产粉嫩一区二区三区在线观看| 亚洲精品老司机| 无码人妻丰满熟妇区五十路百度| 亚洲福利影视| 亚洲老头同性xxxxx| 国产盗摄x88av| 日本va欧美va精品| 久久精品国产综合精品 | 97精品视频在线| 一区二区www| 久久亚洲综合色一区二区三区| 潘金莲一级淫片aaaaa免费看| 欧美大胆性生话| 精品国产免费人成电影在线观看四季| 少妇愉情理伦三级| 性xx色xx综合久久久xx| 亚洲综合在线做性| 婷婷激情在线| 色天天综合色天天久久| 中国特级黄色大片| 午夜精品久久久久久久四虎美女版| 51色欧美片视频在线观看| 国产福利小视频| 亚洲欧美一区二区在线观看| 亚洲性生活网站| 日本国产精品| 久久久噜噜噜久噜久久| 国产偷拍一区二区| 亚洲欧洲成人自拍| 天天干天天草天天| 操欧美老女人| 国产91免费观看| 青青青手机在线视频观看| 亚洲成人在线免费| 国产精品99久久久精品无码| 国产精品成人av| 国产精品免费久久久久久| 久蕉在线视频| 日本高清不卡在线观看| 黄色aaa视频| 久久综合亚州| 欧美日韩在线不卡一区| 日本成人三级电影| 亚洲欧美一区二区三区四区 | 91在线视频| 欧美色网一区二区| аⅴ天堂中文在线网| 日日摸夜夜添夜夜添亚洲女人| 久久久久久精| 超碰超碰人人人人精品| 亚洲欧美激情在线视频| 无码人妻熟妇av又粗又大| 久久九九影视网| 网站一区二区三区| 第一sis亚洲原创| 91精品久久久久久久久久久 | 国色天香2019中文字幕在线观看| 国产成人精品无码高潮| 一区二区三区在线免费观看| 中文字幕avav| 亚洲激情av| 久久综合一区| 99久久久国产精品免费调教网站| 中文字幕亚洲情99在线| 国产乱人乱偷精品视频| 亚洲综合免费观看高清完整版| 黄色激情在线观看| 亚洲一区二区伦理| 日本在线观看一区二区三区| www.精品国产| 欧美精品午夜视频| 熟妇人妻系列aⅴ无码专区友真希 熟妇人妻av无码一区二区三区 | 亚洲电影中文字幕| 伊人中文字幕在线观看| 欧美国产精品劲爆| www.久久com| 99国产精品久久久久久久| 欧美18视频| 青青青国产精品| 欧美大学生性色视频| 五月天福利视频| 欧美吻胸吃奶大尺度电影| 国产精品国产精品88| av在线播放不卡| 999精彩视频| 韩国一区二区三区在线观看| 美国av一区二区三区| 欧美天堂在线| 孩xxxx性bbbb欧美| 91社区在线| 亚洲精品成人av| 96日本xxxxxⅹxxx17| 亚洲1区2区3区视频| 日本在线观看网址| 成人国产一区二区三区精品| 亚洲最大综合网| 1024成人| 综合视频在线观看| 深爱激情综合| 国产三级精品在线不卡| 激情欧美一区二区三区黑长吊| 久久久久久久久久久网站| 国产粉嫩一区二区三区在线观看| 精品奇米国产一区二区三区| 波多野结衣在线电影| 亚洲制服丝袜在线| 超碰人人人人人人人| 成人动漫视频在线| 永久免费黄色片| 日本aⅴ精品一区二区三区| 久久久久久www| 综合视频在线| 亚洲 国产 欧美一区| 人人精品视频| 国产精品三区www17con| 中文字幕成人| 国产精品九九久久久久久久| 精精国产xxx在线视频app| 久久香蕉频线观| av资源在线观看免费高清| 亚洲国产中文字幕久久网| 99re只有精品| 欧美猛男男办公室激情| 无码人妻av免费一区二区三区| 亚洲二区在线观看| 欧美成人一区二区三区高清| 国产精品久久久久久久久果冻传媒 | 男女激情免费视频| 亚洲精品极品少妇16p| 亚洲aⅴ天堂av在线电影软件| 亚洲伊人春色| 久久久久久久久四区三区| 成人激情自拍| 不卡视频一区二区| 日韩在线亚洲| 97伦理在线四区| 亚洲综合网站| 97视频资源在线观看| 国产色99精品9i| 亚洲自拍偷拍视频| av国产精品| 91|九色|视频| 精品视频一区二区三区在线观看| 国产日韩精品视频| 香蕉久久一区| 亚洲自拍偷拍视频| 亚洲国产欧美在线观看| 999在线观看免费大全电视剧| 懂色av色香蕉一区二区蜜桃| 91精品久久久久久| 国产精品日本一区二区不卡视频| 91综合免费在线| 国产一区二区三区免费观看在线 | 青青草免费观看免费视频在线| 亚洲第一视频网| 天堂网av在线播放| 国产视频精品xxxx| 国产精品久久一区二区三区不卡| 国产午夜一区二区| 求av网址在线观看| 欧美大码xxxx| 午夜裸体女人视频网站在线观看| 欧美重口另类videos人妖| 日韩欧美精品一区二区综合视频| 国产精品久在线观看| 91精品网站在线观看| 97超碰资源| 香蕉人人精品| 亚洲一卡二卡三卡| 欧美日本中文| 国产美女无遮挡网站| 日本麻豆一区二区三区视频| www.午夜av| 北条麻妃国产九九精品视频| 亚洲黄色免费视频| 一区二区三区中文在线观看| 国产一级生活片| 在线一区二区三区| 国产激情无套内精对白视频| 亚洲国产精品va在线看黑人动漫| 经典三级在线| 久久久国产在线视频| 成人观看网址| 成人午夜两性视频| 欧美网色网址| 一区国产精品| 国产视频一区三区| 91插插插插插插插插| 成人午夜av影视| 五月天精品在线| 亚洲av少妇一区二区在线观看| 在线观看欧美日本| 亚洲av无码国产综合专区| 日韩精品在线视频美女| 免费看a在线观看| 性欧美xxxx交| 亚洲国产aⅴ精品一区二区三区| 国产亚洲欧美另类一区二区三区| 日韩免费在线| 少妇高潮喷水在线观看| 精品综合久久久久久8888| chinese麻豆新拍video| 国产精品国产三级国产三级人妇| 国产午夜福利精品| 欧美精品日韩一区| 国产精品四虎| 亚洲18私人小影院| 久久69av| 亚洲精品电影在线一区| 亚洲一区二区毛片| 香蕉在线观看视频| 亚洲欧洲日本在线| www.久久网| 国产丝袜高跟一区| 国产盗摄在线视频网站| 91在线播放国产| 久9久9色综合| 久久网站免费视频| 成人av网站在线| 欧美成人精品欧美一级私黄| 欧美日韩dvd在线观看| 国产最新视频在线| 91精品国产高清自在线看超| 亚洲日本视频在线| 日韩中文在线字幕| 久久97超碰国产精品超碰| 国产真人做爰视频免费| 欧美日韩国产中文字幕| 亚洲免费不卡视频| 欧美激情国产精品| 麻豆国产一区| 日韩视频一二三| 国产毛片精品一区| 91视频青青草| 7777女厕盗摄久久久| 在线观看av的网站| 国产区亚洲区欧美区| 色喇叭免费久久综合| 国产又黄又猛又粗| 中文字幕欧美激情| 人妻中文字幕一区二区三区| 亚洲天堂第一页| 三上悠亚一区二区| 欧美日韩一区二区三| 亚洲免费影视| 久久精品国产亚洲AV熟女| 都市激情亚洲色图| 青青草在线免费视频| 欧美最猛性xxxx| 国产真实有声精品录音| mm1313亚洲国产精品无码试看| 国产婷婷精品av在线| 丰满人妻一区二区三区四区| 最好看的2019的中文字幕视频| 国产一区精品福利| 永久免费在线看片视频| 国产成人av网站| 国产精品.www| 日韩国产在线播放| 国精产品一区二区三区有限公司| 欧美在线播放一区| 麻豆久久久久久久| 亚洲波多野结衣| 日韩欧美视频在线| 成人bbav| 亚洲精品中字| 国产乱码精品一区二区三区五月婷| 青青操国产视频| 日韩av在线一区| 日本久久免费| 日本道在线视频| 不卡一区在线观看| 久久久蜜桃一区二区| 久久久精品国产一区二区| 日韩区一区二| 国产精品69页| 自拍偷自拍亚洲精品播放| 欧日韩在线视频| 国产成人啪精品视频免费网| 四季av一区二区凹凸精品| 中文字幕无人区二| 日韩欧美国产高清91| 一区二区三区视频在线观看视频| 97超级碰碰| 久色成人在线| 91在线播放观看| 日韩av在线网页| 电影一区二区三区久久免费观看| 欧美黑人经典片免费观看 | 久久久久久一区| 久久精品国产色蜜蜜麻豆| 日本特黄一级片| 丝袜美腿精品国产二区| 国产精品18hdxxxⅹ在线| www.激情小说.com| 亚洲国产精品久久人人爱蜜臀| 成年人在线观看视频|