zoukankan      html  css  js  c++  java
  • redis 基本类型

    1 hashes 类型及操作

    redis hash 是一个string 类型的 field 和 value 的映射表。他的添加、删除操作时间复杂度都是 O(1)

    2 hset,设置 hash field 为指定值,如果 key 不存在,则先创建。

    redis 127.0.0.1:6379> hset myhash field1 Hello
    (integer) 1

    3 hsetnx,设置 hash field 为指定值,如果 key 不存在,则先创建。如果 field 已经存在,返回 0,nx 是not exist 的意思。

    redis 127.0.0.1:6379> hsetnx myhash field "Hello"
    (integer) 1

    4 hmset,同时设置 hash 的多个 field。

    redis 127.0.0.1:6379> hmset myhash field1 Hello field2 World
    OK

    5 hget,获取指定的 hash field。

    redis 127.0.0.1:6379> hget myhash field1
    "Hello"

    6 hmget,获取全部指定的 hash filed。

    redis 127.0.0.1:6379> hmget myhash field1 field2 field3
    1) "Hello"
    2) "World"
    3) (nil)

    7 hincrby,指定的 hash filed 加上给定值。

    redis 127.0.0.1:6379> hset myhash field3 20
    (integer) 1
    redis 127.0.0.1:6379> hget myhash field3
    "20"
    redis 127.0.0.1:6379> hincrby myhash field3 -8
    (integer) 12
    redis 127.0.0.1:6379> hget myhash field3
    "12"

    8 hexists,测试指定 field 是否存在。

    redis 127.0.0.1:6379> hexists myhash field1
    (integer) 1

    9 hlen,返回指定 hash 的 field 数量。

    redis 127.0.0.1:6379> hlen myhash
    (integer) 4

    10 hdel,删除指定 field,并返回指定 hash 的 field 数量。

    redis 127.0.0.1:6379> hlen myhash
    (integer) 4
    redis 127.0.0.1:6379> hdel myhash field1
    (integer) 1
    redis 127.0.0.1:6379> hlen myhash
    (integer) 3

    11 hkeys,返回 hash 的所有 field。

    redis 127.0.0.1:6379> hkeys myhash
    1) "field2"
    2) "field"
    3) "field3"

    12 hvals,返回 hash 的所有 value。

    redis 127.0.0.1:6379> hvals myhash
    1) "World"
    2) "Hello"
    3) "12"

    13 hgetall,获取某个 hash 中全部的 filed 及 value。

    14 lists,Redis 的 list 类型其实就是一个每个子元素都是 string 类型的双向链表。链表的最大长度是(2的 32 次方)。我们可以通过 push,pop 操作从链表的头部或者尾部添加删除元素。这使得 list

    既可以用作栈,也可以用作队列。

    lpush,在 key 对应 list 的头部添加字符串元素

    rpush,在 key 对应 list 的尾部添加字符串元素

    linsert,在 key 对应 list 的特定位置之前或之后添加字符串元素,

    redis 127.0.0.1:6379> rpush mylist3 "hello"
    (integer) 1
    redis 127.0.0.1:6379> rpush mylist3 "world"
    (integer) 2
    redis 127.0.0.1:6379> linsert mylist3 before "world" "there"
    (integer) 3

    lset,设置 list 中指定下标的元素值(下标从 0 开始)

    lrem,从 key 对应 list 中删除 count 个和 value 相同的元素。count>0 时,按从头到尾的顺序删除。count=0 时,删除全部。

    ltrim,保留指定 key 的值范围内的数据。

    redis 127.0.0.1:6379> rpush mylist8 "one"
    (integer) 1
    redis 127.0.0.1:6379> rpush mylist8 "two"
    (integer) 2
    redis 127.0.0.1:6379> rpush mylist8 "three"
    (integer) 3
    redis 127.0.0.1:6379> rpush mylist8 "four"
    (integer) 4
    redis 127.0.0.1:6379> ltrim mylist8 1 -1
    OK
    redis 127.0.0.1:6379> lrange mylist8 0 -1
    1) "two"
    2) "three"
    3) "four"

    lpop,从 list 的头部删除元素,并返回删除元素。

    rpop,从 list 的尾部删除元素,并返回删除元素。

    redis 127.0.0.1:6379> lrange mylist 0 -1
    1) "hello"
    2) "world"
    redis 127.0.0.1:6379> lpop mylist
    "hello"
    redis 127.0.0.1:6379> lrange mylist 0 -1
    1) "world"

    rpoplpush,

    从第一个 list 的尾部移除元素并添加到第二个 list 的头部,最后返回被移除的元素值,整个操作是原子的.如果第一个 list 是空或者不存在返回 nil。

    redis 127.0.0.1:6379> lrange mylist5 0 -1
    1) "three"
    2) "foo"
    3) "hello"
    redis 127.0.0.1:6379> lrange mylist6 0 -1
    1) "hello"
    2) "foo"
    redis 127.0.0.1:6379> rpoplpush mylist5 mylist6
    "hello"
    redis 127.0.0.1:6379> lrange mylist5 0 -1
    1) "three"
    2) "foo"
    redis 127.0.0.1:6379> lrange mylist6 0 -1
    1) "hello"
    2) "hello"
    3) "foo"

    lindex,返回名称为 key 的 list 中 index 位置的元素

    redis 127.0.0.1:6379> lrange mylist5 0 -1
    1) "three"
    2) "foo"
    redis 127.0.0.1:6379> lindex mylist5 0
    "three"

    llen,返回 key 对应 list 的长度

    redis 127.0.0.1:6379> llen mylist5
    (integer) 2

    15 set

    set 是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中 key 理解为集合的名字。

    Redis 的 set 是 string 类型的无序集合。set 元素最大可以包含(2 的 32 次方)个元素。

    set 的是通过 hash table 实现的,所以添加、删除和查找的复杂度都是 O(1)。

    sadd,向名称为 key 的 set 中添加元素

    srem,删除名称为 key 的 set 中的元素 member

    redis 127.0.0.1:6379> sadd myset2 "one"
    (integer) 1
    redis 127.0.0.1:6379> sadd myset2 "two"
    (integer) 1
    redis 127.0.0.1:6379> sadd myset2 "three"
    (integer) 1
    redis 127.0.0.1:6379> srem myset2 "one"
    (integer) 1
    redis 127.0.0.1:6379> srem myset2 "four"
    (integer) 0
    redis 127.0.0.1:6379> smembers myset2
    1) "three"
    2) "two"

    spop,随机返回并删除名称为 key 的 set 中一个元素

    sdiff,返回所有给定 key 与第一个 key 的差集

    sdiffstore,返回所有给定 key 与第一个 key 的差集,并将结果存为另一个 key

    redis 127.0.0.1:6379> smembers myset2
    1) "three"
    2) "two"
    redis 127.0.0.1:6379> smembers myset3
    1) "two"
    2) "one"
    redis 127.0.0.1:6379> sdiffstore myset4 myset2 myset3
    (integer) 1
    redis 127.0.0.1:6379> smembers myset4
    1) "three"

    sinter,返回所有给定 key 的交集

    redis 127.0.0.1:6379> smembers myset2
    1) "three"
    2) "two"
    redis 127.0.0.1:6379> smembers myset3
    1) "two"
    2) "one"
    redis 127.0.0.1:6379> sinter myset2 myset3
    1) "two"

    sinterstore,返回所有给定 key 的交集,并将结果存为另一个 key

    sunion,返回所有给定 key 的并集

    sunionstore,返回所有给定 key 的并集,并将结果存为另一个 key

    smove,从第一个 key 对应的 set 中移除 member 并添加到第二个对应 set 中

    redis 127.0.0.1:6379> smembers myset2
    1) "three"
    2) "two"
    redis 127.0.0.1:6379> smembers myset3
    1) "two"
    2) "one"
    redis 127.0.0.1:6379> smove myset2 myset7 three
    (integer) 1
    redis 127.0.0.1:6379> smembers myset7
    1) "three"

    scard,返回名称为 key 的 set 的元素个数

    sismember,测试 member 是否是名称为 key 的 set 的元素。

    redis 127.0.0.1:6379> smembers myset2
    1) "two"
    redis 127.0.0.1:6379> sismember myset2 two
    (integer) 1
    redis 127.0.0.1:6379> sismember myset2 one
    (integer) 0
  • 相关阅读:
    初学者易上手的SSH-spring 01控制反转(IOC)
    初学者易上手的SSH-hibernate04 一对一 一对多 多对多
    初学者易上手的SSH-hibernate03 三大状态与缓存
    初学者易上手的SSH-hibernate02 三种查询方式
    初学者易上手的SSH-hibernate01环境搭建
    Maven-环境搭建以及建立Maven项目
    初学者易上手的SSH-struts2 05拦截器与自定义拦截器
    初学者易上手的SSH-struts2 04值栈与ognl表达式
    screen常用操作总结
    word2016教程:使用密码保持修订
  • 原文地址:https://www.cnblogs.com/zhaopengcheng/p/7494964.html
Copyright © 2011-2022 走看看