redis学习(四)

一、Redis 键(key)

1、Redis 键命令用于管理 redis 的键。

2、Redis 键命令的基本语法如下:redis 127.0.0.1:6379> COMMAND KEY_NAME

3、常用key命令

   keys *           获取所有的key
    select 0         选择第一个库
    move myString 1  将当前的数据库key移动到某个数据库,目标库有,则不能移动
    flush db         清除指定库
    randomkey        随机key
    type key         类型
    
    set key1 value1  设置key
    get key1         获取key
    mset key1 value1 key2 value2 key3 value3
    mget key1 key2 key3
    del key1         删除key
    exists key       判断是否存在key
    expire key 10    10过期
    pexpire key 1000 毫秒
    persist key      删除过期时间

二、Redis 字符串(String)

1、Redis 字符串数据类型的相关命令用于管理 redis 字符串值,基本语法如下:COMMAND KEY_NAME

2、常用命令

    set name cxx        设置name为cxx
    get name           获取name
    getrange name 0 -1        字符串分段
    getset name new_cxx       设置值,返回旧值
    mset key1 key2            批量设置
    mget key1 key2            批量获取
    setnx key value           不存在就插入(not exists)
    setex key time value      过期时间(expire)
    setrange key index value  从index开始替换value
    incr age        递增
    incrby age 10   递增
    decr age        递减
    decrby age 10   递减
    incrbyfloat     增减浮点数
    append          追加
    strlen          长度
    getbit/setbit/bitcount/bitop    位操作

三、Redis 哈希(Hash)

1、Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。

     Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。

2、常用命令

   hset myhash name cxx
    hget myhash name
    hmset myhash name cxx age 25 note "i am notes"
    hmget myhash name age note   
    hgetall myhash               获取所有的
    hexists myhash name          是否存在
    hsetnx myhash score 100      设置不存在的
    hincrby myhash id 1          递增
    hdel myhash name             删除
    hkeys myhash                 只取key
    hvals myhash                 只取value
    hlen myhash                  长度

四、Redis 列表(List)

1、Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)

一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

2、常用命令

lpush mylist a b c  左插入
rpush mylist x y z  右插入
lrange mylist 0 -1  数据集合
lpop mylist         弹出元素
rpop mylist         弹出元素
llen mylist         长度
lrem mylist count value  删除
lindex mylist 2          指定索引的值
lset mylist 2 n          索引设值
ltrim mylist 0 4         删除key
linsert mylist before a  插入
linsert mylist after a   插入
rpoplpush list list2     转移列表的数据

 

五、Redis 集合(Set)

1、Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。

2、Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

3、常用命令

sadd myset redis    向名为myset集合中插入元素redis
smembers myset       数据集合
srem myset set1      删除
sismember myset set1 判断元素是否在集合中
scard key_name       个数
sdiff | sinter | sunion 操作:集合间运算:差集 | 交集 | 并集
srandmember          随机获取集合中的元素
spop                 从集合中弹出一个元素

六、Redis 有序集合(sorted set)

1、Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员

   不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

2、有序集合的成员是唯一的,但分数(score)却可以重复。

3、集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

4、常用命令

zadd zset 1 one          向名为zset的有序集合中添加值one并关联上分数1
zadd zset 2 two
zadd zset 3 three
zincrby zset 1 one              增长分数
zscore zset two                 获取分数
zrange zset 0 -1 withscores     范围值
zrangebyscore zset 10 25 withscores 指定范围的值
zrangebyscore zset 10 25 withscores limit 1 2 分页
Zrevrangebyscore zset 10 25 withscores  指定范围的值
zcard zset  元素数量
Zcount zset 获得指定分数范围内的元素个数
Zrem zset one two        删除一个或多个元素
Zremrangebyrank zset 0 1  按照排名范围删除元素
Zremrangebyscore zset 0 1 按照分数范围删除元素
Zrank zset 0 -1    分数最小的元素排名为0
Zrevrank zset 0 -1  分数最大的元素排名为0

七、Redis HyperLogLog

1、Redis HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定的、并且是很小的

   在Redis里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基 数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。

   但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。

2、基数:集合中不同元素的数量。比如 {'apple', 'banana', 'cherry', 'banana', 'apple'} 的基数就是 3 。

  估算值:算法给出的基数并不是精确的,可能会比实际稍微多一些或者稍微少一些,但会控制在合理的范围之内。

3、常用命令:

  PFADD key element [element ...]:将任意数量的元素添加到指定的 HyperLogLog 里面。

  PFCOUNT key [key ...] : 返回给定 HyperLogLog 的基数估算值

  PFMERGE destkey sourcekey [sourcekey ...]:将多个 HyperLogLog 合并为一个 HyperLogLog ,合并后的 HyperLogLog 的基数估算值是通过对所有
给定 HyperLogLog 进行并集计算得出的。

借鉴博客:https://www.cnblogs.com/cxxjohnson/p/9072383.html

     https://www.runoob.com/redis/redis-hyperloglog.html

     https://www.cnblogs.com/ysuzhaixuefei/p/4052110.html

原文地址:https://www.cnblogs.com/dongtian-blogs/p/10801305.html