Redis 基本数据类型以及相应操作

〇、常用命令

select <num> 选择库0~15 默认0号库

key * 查看当前库所有键(可以接正则表达式)

exists <key>

type <key>

del <key>

expire <key> <seconds>  为键设置过期时间,单位秒。

ttl <key> 查看还有多少秒过期 (-1表示永不过期 -2已过期)

dbsize 查看当前数据库key的数量

flushdb 清空当前库 (flushall 清空全部库)

一、String

String是redis最基本的类型,单个string最多512M。

get <key>                                  mget <key1> <key2>...  //设置多个

set <key> <value>                    mset <key1> <value1> <key2> <value2>...  //多个

append <key> <value>

strlen <key>                        

setnx <key> <value>                 mesetnx   <key1> <value1> <key2> <value2>   //全部不存在时才生效

------------set if not exist    

incr/decr <key>   (纯数字字符串)增长/减小 1(不存在先初始化0)

incrby/decrby <key> <value> 对应键的值 增/减 步长

getrange <key> <起始位置,从0,包含><结束位置,包含> 取子串  -------负数表示倒数第几个

setrange <key> <起始位置> <value> 用value覆写key所存储的字符串值,从起始位置开始 

setex <key> <过期时间(秒)> <value> 设置键值跟过期时间(set后过期时间会刷新)

getset <key> <value> 以新换旧

二、list  双向链表。。。值在键在,值光键亡。

lpush/rpush <key> <value1> <value2>... 从左边/右边插入一个或者多个值

lpop/rpop <key> 从左/右弹出一个值

lrange <key> <start> <end> 返回链表中start到end的元素

rpoplpush <key1> <key2> 从key1列表右弹出一个值插入到key2左处。

llen <key>  元素个数

lrem <key> <count> <value> 从链表头删除value值,删除count的绝对值个value后结束 count>0从头开始 <0从尾删除 =0全部删除

linsert <key> [before|after] <search> <value> 在search 前/后插入value 为查到search插入失败。

三、Set 无序集合 。。人在塔在。人去楼空

sadd <key> <value> <value>..

smembers <key>             取出集合中所有元素

sismember <key> <value>   判断集合中是否含有value 有返回1 没有返回0

srem <key> <value1> <value2>...         删除

spop <key> 返回并删除集合中一个随机元素

srandmember <key> <n> 随机返回n个集合中元素

scard <key> 返回集合中元素个数

sinter <key1> <key2> 交集

sunion <key1> <key2> 并集

sdiff <key1> <key2> 差集

(上面三个)store <res> <key1> <key2> 求两个集合的(交并差)存在res里

四、Hash

Redis hash 是一个string类型的field和value的映射表,它的添加、删除操作都是O(1)(平均)。hash特别适用于存储对象,将一个对象存储在hash类型中会占用更少的内存,并且可以方便的存取整个对象。

  配置: hash_max_zipmap_entries 64 #配置字段最多64个

      hash_max_zipmap_value 512 #配置value最大为512字节

hset <key> <field> <value> 给key集合中的 field键对应的值赋值value

hsetnx <key> <field> <value>

hmset <key> <field1> <value1>  <field2> <value2>  批量赋值

hget <key> <field> 取指定key 指定field中的值

hmget <key> <field1> <field2> 批量取值

hexists <key> <field> 查看指定field是否存在

hlen <key> 返回field数量

hdel <key> <field> 删除指定field

hkeys <key>            hvals<key>     hgetall<key>获取某个hash中全部的field/value/field及value

hincrby <key> <field> <x> 增加x

五、zset

redis 中zset与普通set非常相似,是一个没有重复元素的字符串集合。不同之处是zset的每个成员都关联了一个(double)score 用来排序,在value被创建或修改时可以指定其值。底层实现是skip list 和 hashtable的混合体。

当元素被添加到集合中时,一个元素到score的映射被添加到hash table中,所以给定一个元素获取score的开销是O(1)。另一个score到元素的映射被添加的skip list,并按照score排序,所以就可以有序地获取集合中的元素。添加、删除操作开销都是O(logN)和skip list的开销一致,redis的skip list 实现是双向链表,这样就可以逆序从尾部去元素。sorted set最经常使用方式应该就是作为索引来使用,我们可以把要排序的字段作为score存储,对象的ID当元素存储。

zadd <key> <score1> <value1>

zrange <key> <start> <stop> 把排序后的结果返回 (默认score升序)

z(rev)rank <key> <value> 查询对饮value的排名,(默认升序,rev按降序排列)

zrem <key> <value>... 删除

zremrangebyscore <key> min max  删除 score属于 [min,max]

zremrangebyrank <key>start end 删除 名次属于[start,end]

zcard  <key> 返回集合中元素的个数

zcount <key> <min> <max> 返回score在区间[min,max]内的元素个数

posted @ 2019-04-08 21:05  茶饭不撕  阅读(137)  评论(0编辑  收藏  举报