Redis数据类型(String,Hash,List)

Redis数据类型

1 String

1.1 命令

1.1.1赋值

语法:SET key value

127.0.0.1:6379> set test 123
OK
1.1.2 取值

语法:GET key

127.0.0.1:6379> get test
"123“
1.1.3 取值并赋值

语法:GETSET key value

127.0.0.1:6379> getset s2 222
"111"
127.0.0.1:6379> get s2
"222"
1.1.4 设置/获取多个键值

语法:

MSET key value [key value …]

MGET key [key …]

127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> mget k1 k3
1) "v1"
2) "v3"
1.1.5 删除

语法:DEL key

127.0.0.1:6379> del test
(integer) 1
1.1.6 数值增减
  • 递增数字

    当存储的字符串是整数时,Redis提供了一个实用的命令INCR,其作用是让当前键值递增,并返回递增后的值。

    语法:INCR key

    127.0.0.1:6379> incr num
    (integer) 1
    127.0.0.1:6379> incr num
    (integer) 2
    127.0.0.1:6379> incr num
    (integer) 3
    
  • 增加指定的整数

    语法:INCRBY key increment

    127.0.0.1:6379> incrby num 2
    (integer) 5
    127.0.0.1:6379> incrby num 2
    (integer) 7
    127.0.0.1:6379> incrby num 2
    (integer) 9
    
  • 递减数值

    语法:DECR key

    127.0.0.1:6379> decr num
    (integer) 9
    127.0.0.1:6379> decr num
    (integer) 8
    
  • 减少指定的整数

    语法:DECRBY key decrement

    127.0.0.1:6379> decr num
    (integer) 6
    127.0.0.1:6379> decr num
    (integer) 5
    127.0.0.1:6379> decrby num 3
    (integer) 2
    127.0.0.1:6379> decrby num 3
    (integer) -1
    
1.1.7 其他命令
  • 向尾部追加值

    APPEND的作用是向键值的末尾追加value。如果键不存在则将该键的值设置为value,即相当于 SET key value。返回值是追加后字符串的总长度。

    语法:APPEND key value

    127.0.0.1:6379> set str hello
    OK
    127.0.0.1:6379> append str " world!"
    (integer) 12
    127.0.0.1:6379> get str 
    "hello world!"
    
  • 获取字符串长度

    STRLEN命令返回键值的长度,如果键不存在则返回0。

    语法:STRLEN key

    127.0.0.1:6379> strlen str 
    (integer) 0
    127.0.0.1:6379> set str hello
    OK
    127.0.0.1:6379> strlen str 
    (integer) 5
    

1.2 应用

1.2.1 自增主键

商品编号、订单号采用string的递增数字特性生成。

定义商品编号key:items:id

192.168.101.3:7003> INCR items:id
(integer) 2
192.168.101.3:7003> INCR items:id
(integer) 3

2. Hash

散列类型

2.1 使用String的问题

假设有User对象以JSON序列化的形式存储到Redis中,User对象有id,username、password、age、name等属性,存储的过程如下:

保存、更新:

User对象 ——> json(string) ——> redis

如果在业务上只是更新age属性,其他的属性并不做更新我应该怎么做呢?如果仍然采用上边的方法在传输、处理时会造成资源浪费,下边讲的hash可以很好的解决这个问题。

2.2 redis hash 介绍

​ hash叫散列类型,它提供了字段和字段值的映射。字段值只能是字符串类型,不支持散列类型、集合类型等其它类型。如下:

020.PNG

2.3 命令

2.3.1 赋值

HSET命令不区分插入和更新操作,当执行插入操作时HSET命令返回1,当执行更新操作时返回0。

  • 一次只能设置一个字段值

    语法:HSET key field value

    127.0.0.1:6379> hset user username zhangsan 
    (integer) 1
    
  • 一次可以设置多个字段值

    语法:HMSET key field value [field value ...]

    127.0.0.1:6379> hmset user age 20 username lisi 
    OK
    
  • 当字段不存在时赋值,类似HSET,区别在于如果字段存在,该命令不执行任何操作

    语法:HSETNX key field value

    127.0.0.1:6379> hsetnx user age 30    如果user中没有age字段则设置age值为30,否则不做任何操作
    (integer) 0
    
2.3.2 取值
  • 一次只能获取一个字段值

    语法:HGET key field

    127.0.0.1:6379> hget user username
    "zhangsan"
    
  • 一次可以获取多个字段值

    语法:HMGET key field [field ...]

    127.0.0.1:6379> hmget user age username
    1) "20"
    2) "lisi"
    
  • 获取所有字段值

    语法:HGETALL key

    127.0.0.1:6379> hgetall user
    1) "age"
    2) "20"
    3) "username"
    4) "lisi"
    
2.3.3 删除字段

可以删除一个或多个字段,返回值是被删除的字段个数

语法:HDEL key field [field...]

127.0.0.1:6379> hdel user age
(integer) 1
127.0.0.1:6379> hdel user age name
(integer) 0
127.0.0.1:6379> hdel user age username
(integer) 1 
2.3.4 增加数字

语法:HINCRBY key field increment

127.0.0.1:6379> hincrby user age 2  将用户的年龄加2
(integer) 22
127.0.0.1:6379> hget user age       获取用户的年龄
"22"
2.3.5 其它命令
  1. 判断字段是否存在

    语法:HEXISTS key field

    127.0.0.1:6379> hexists user age     查看user中是否有age字段
    (integer) 1
    127.0.0.1:6379> hexists user name    查看user中是否有name字段
    (integer) 0
    
  2. 只获取字段名或字段值

    语法:

    HKEYS key

    HVALS key

    127.0.0.1:6379> hmset user age 20 name lisi 
    OK
    127.0.0.1:6379> hkeys user
    1) "age"
    2) "name"
    127.0.0.1:6379> hvals user
    1) "20"
    2) "lisi"
    
  3. 获取字段数量

    语法:HLEN key

    127.0.0.1:6379> hlen user
    (integer) 2
    

2.4 应用

2.4.1 存储商品信息
  • 商品字段

    【商品id、商品名称、商品描述、商品库存、商品好评】

  • 定义商品信息的key

    商品1001的信息在 Redis中的key为:[items:1001]

  • 存储商品信息

    192.168.101.3:7003> HMSET items:1001 id 3 name apple price 999.9
    OK
    
  • 获取商品信息

    192.168.101.3:7003> HGET items:1001 id
    "3"
    192.168.101.3:7003> HGETALL items:1001
    1) "id"
    2) "3"
    3) "name"
    4) "apple"
    5) "price"
    6) "999.9"
    

3. List

3.1 ArrayList和LinkedList的区别

Arraylist是使用数组来存储数据,特点:查询快、增删慢

Linkedlist是使用双向链表存储数据,特点:增删快、查询慢,但是查询链表两端的数据也很快。

Redis的list是采用来链表来存储的,所以对于redis的list数据类型的操作,是操作list的两端数据来操作的。

3.2 命令

3.2.1 向列表两端增加元素

  • 向列表左边增加元素

    语法:LPUSH key value [value ...]

    127.0.0.1:6379> lpush list1 1 2 3
    (integer) 3
    
  • 向列表右边增加元素

    语法:RPUSH key value [value ...]

    127.0.0.1:6379> rpush list1 4 5 6
    (integer) 3
    

3.2.2 查看列表

LRANGE命令是列表类型最常用的命令之一,获取列表中的某一片段,将返回start、stop之间的所有元素(包含两端的元素),索引从0开始。索引可以是负数,如:“-1”代表最后边的一个元素

语法:LRANGE key start stop

127.0.0.1:6379> lrange list1 0 2
1) "2"
2) "1"
3) "4"

127.0.0.1:6379> lrange list1 0 -1

3.2.3 从列表两端弹出元素

LPOP命令从列表左边弹出一个元素,会分两步完成:

第一步是将列表左边的元素从列表中移除

第二步是返回被移除的元素值。

语法:

LPOP key

RPOP key

127.0.0.1:6379> lpop list1
"3“
127.0.0.1:6379> rpop list1
"6“

3.2.4 获取列表中元素的个数

语法:LLEN key

127.0.0.1:6379> llen list1
(integer) 2

3.2.5 其它命令

  1. 删除列表中指定的值

    LREM命令会删除列表中前count个值为value的元素,返回实际删除的元素个数。根据count值的不同,该命令的执行方式会有所不同:

    • 当count>0时, LREM会从列表左边开始删除。
    • 当count<0时, LREM会从列表后边开始删除。
    • 当count=0时, LREM删除所有值为value的元素。

    语法:LREM key count value

  2. 获得/设置指定索引的元素值

    • 获得指定索引的元素值

      语法:LINDEX key index

      127.0.0.1:6379> lindex list1 2
      "1"
      
    • 设置指定索引的元素值

      语法:LSET key index value

      127.0.0.1:6379> lset list1 2 2
      OK
      127.0.0.1:6379> lrange list1 0 -1
      1) "6"
      2) "5"
      3) "2"
      4) "2"
      
    • 只保留列表指定片段

      指定范围和LRANGE一致

      语法:LTRIM key start stop

      127.0.0.1:6379> lrange list1 0 -1
      1) "6"
      2) "5"
      3) "0"
      4) "2"
      127.0.0.1:6379> ltrim list1 0 2
      OK
      127.0.0.1:6379> lrange list1 0 -1
      1) "6"
      2) "5"
      3) "0"
      
    • 向列表中插入元素

      该命令首先会在列表中从左到右查找值为pivot的元素,然后根据第二个参数是BEFORE还是AFTER来决定将value插入到该元素的前面还是后面。

      语法:LINSERT key BEFORE|AFTER pivot value

      127.0.0.1:6379> lrange list1 0 -1
      1) "3"
      2) "2"
      3) "1"
      127.0.0.1:6379> linsert list1 after 3 4
      (integer) 4
      127.0.0.1:6379> lrange list1 0 -1
      1) "3"
      2) "4"
      3) "2"
      4) "1"
      
    • 将元素从一个列表转移到另一个列表中

      语法:RPOPLPUSH source destination

      127.0.0.1:6379> rpoplpush list newlist 
      "1"
      127.0.0.1:6379> lrange newlist 0 -1
      1) "1"
      127.0.0.1:6379> lrange list 0 -1
      1) "3"
      2) "4"
      3) "2"
      

3.3 应用

3.3.1 商品评论列表

思路:

在Redis中创建商品评论列表

用户发布商品评论,将评论信息转成json存储到list中。

用户在页面查询评论列表,从redis中取出json数据展示到页面。

定义商品评论列表key:

商品编号为1001的商品评论key【items: comment:1001】

192.168.101.3:7001> LPUSH items:comment:1001 '{"id":1,"name":"商品不错,很好!!","date":1430295077289}'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容

  • redis是一个以key-value存储的非关系型数据库。有五种数据类型,string、hashes、list、s...
    林ze宏阅读 990评论 0 0
  • 1 Redis介绍1.1 什么是NoSql为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方...
    克鲁德李阅读 5,283评论 0 36
  • 五种基本类型及其用法 STRING类型 获得符合规则的键名列表 KEYS pattern pattern可以以gl...
    nailding阅读 891评论 0 49
  • Redis 的 list 类型其实就是一个每个子元素都是 string 类型的双向链表。主要功能是 push、po...
    鬭闢阅读 320评论 0 0
  • 常用管理命令 1、启动Redis >redis-server[--port6379] 如果命令参数过多,建议通过配...
    weizilong阅读 619评论 0 0