`

redis基础

 
阅读更多

3》启动和停止Redis

 

直接启动

redis-server

redis-server /ect/redis.conf

停止Redis

shutdown

结束Redis的进程也可以

3.命令返回值

 

1》状态回复

ping

 

SET test 'this is a test'

2》错误回复

 

错误回复以error开始

(error) ERR unknown command 'TESTERROR'

 

3》整数回复:

 

以interger 数值

(integer) 2

 

4》字符串回复

 

GET test

 

(nil)代表空的结果

 

5》多行字符串回复

 

KEYS *,得到当前数据库中的存在的键名

 

4.Redis配置选项相关内容

 

1》动态设置/获取配置选项的值

 

获取:

CONFIG GET name

1)"port"

2)"6379"

 

设置:

CONFIG SET name value

 

2》Redis配置文件redis.conf选项相关

 

--连接选项--

 

port 6379 默认端口

 

bind 127.0.0.1,默认绑定的主机地址

 

timeout 0,当客户端闲置多久之后关闭连接,0代表没有启动这个选项

 

loglevel notice,日志的记录级别

 

# debug:很详细的信息,适合开发和测试

# verbose :包含很多不太有用的信息

# notice :比较适合生产环境

# warning :警告信息

 

logfile stdout,日志的记录方式,默认为标准输出

 

databases 16,默认数据库的数量16个,默认的数据库编号从0开始

 

 

--快照--

 

save <seconds> <changes>:多少秒有多少次改变将其同步到磁盘中数据文件里

save 900 1--900秒内有一个更改

save 300 10--300秒内有10个更改

save 60 10000--60秒内有10000个更改

 

 

rdbcompression yes,存储本地数据库时是否启用压缩,默认yes

 

dbfilename dump.rdb,指定本地数据库文件名,默认为dump.rdb

 

dir ./,指定本地数据库的存放目录,默认是当前目录

 

5.Redis的数据类型

 

String字符串类型

一个键最多存储512MB

1》SET:设置key对应的值为value

 

语法:SET key value [EX seconds] [PX milliseconds] [NX|XX]

EX seconds:设置键的key的过期时间SET key value EX seconds -- SETEX

PX milliseconds:以毫秒的形式设置过期时间SET key value PX milliseconds--PSETEX

NX:只有键不存在的时候才可以设置成功SET key value NX--SETNX

XX:只有key已经存在的时候才可以设置

 

SET test16 'this is a test16' EX 100

SET test17 'this is a test17' PX 20000

SET test18 'this is a test18' NX

SET test18 'this is a test18888' XX

 

SET test19 'this is a test19' EX 100 NX

 

SET test20 'this is a test20' EX 100 PX 300000 NX

 

SET testStr1 'this is a test'

 

 

注意:如果key存在,同名会产生覆盖

 

2》GET:根据key找到对应的值

 

语法:GET key

 

GET testStr1

 

注意:如果key不存在,返回nil

 

如果key不是字符串,会报错

 

3》GETRANGE:返回字符串中一部分

 

语法:GETRANGE key start end

 

GETRANGE testStr2 0 4

 

GETRANGE testStr2 0 -3

 

GETRANGE testStr2 -4 -2

 

GETRANGE testStr2 0 1000

 

4》GETSET:设置指定key的值,并且返回旧的值

 

语法:GETSET key value

 

SET testStr3 'king'

 

GET testStr3

 

GETSET testStr3 'queen'

 

注意:当key不存在返回nil

如果key不是字符串,会报错

 

5》MSET:一次设置多个键值对

 

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

 

MSET testStr5 'king' testStr6 'maizi' testStr7 'queen'

 

 

6》MGET:一次得到多个键值

 

语法:MGET key key

 

MGET testStr5 testStr6 testStr7

 

MGET testStr5 testStr6 testStr7 testStr8

 

7》STRLEN:获取key的字符串长度

 

语法:STRLEN key

 

STRLEN testStr5

 

注意:对于不存在key获取其长度返回的0

 

8》SETRANGE:相当于字符串替换的效果

 

语法:SETRANGE key offset value

 

注意:如果设置的key原来的字符串长度要比偏移量小,就会以零字节(\x00)来填充

 

SET testStr9 'hello king'

 

SETRANGE testStr9 6 'queen'

 

对不存在的key使用SETRANGE

 

EXISTS testStr10

 

SETRANGE testStr10 5 'king'

 

9》SETNX:只有key不存在才能设置成功

 

语法:SETNX key value

 

EXISTS testStr11 

 

SETNX testStr11 'maizi'

 

GET testStr11

 

SETNX testStr11 'maiziedu'

 

GET testStr11

 

10》SETEX:设置key并且设置其过期时间

 

语法:SETEX key seconds value

 

SETEX expireStr 60 'testExpire'

 

注意:SETEX是原子性操作,相当于执行了SET key value,又对这个key设置了过期时间EXPIRE key seconds

 

SET expireStr1 'test1'

 

EXPIRE expireStr1 10

 

SETEX test12 1000 'a'

 

GET test12

 

11》MSETNX:一次设置多个key-value对,只有所有的key都不存在的时候才会成功

 

语法:MSETNX key value [key value]

 

MSETNX test13 'a' test14 'b' test15 'c'

 

MSETNX test15 'aa' test16 'bb' test17 'cc'

 

12》PSETEX:以毫秒为单位设置key的生存周期

 

语法:PSETEX key milliseconds value

 

PSETEX test16 2000 'hello world'

 

PTTL

 

13》INCR:对key中存储的数字+1

 

语法:INCR key

 

SET counter 1

 

INCR counter

 

注意:key如果不存在,则会先初始化为0,在进行INCR操作

 

如果key存储的不是数字,会报错

 

INCR counter1

 

INCR test20

 

14》INCRBY:将key中存储的数字加上指定增量

 

语法:INCRBY key INCREMENT

 

SET counter2 10

 

INCRBY counter2 5

 

INCRBY counter2 1.2

 

15》INCRBYFLOAT:给key中存储的数字加上指定的浮点数

 

语法:INCRBYFLOAT key increment

 

SET counter3 1

 

INCRBYFLOAT counter3 1.2

 

 

16》DECR:将key中存储的数字减1

 

语法:DECR key

 

DECR counter3

 

 

17》DECRBY:将key中存储的数值减去指定的值

 

语法:DECRBY key decrement

 

DECRBY counter2 3

 

18》APPEND:通过APPEND将值追加到字符串的末尾

 

语法:APPEND key value

 

注意:如果key不存在,则相当于执行的SET操作

 

 

APPEND testStr11 'edu'

 

APPEND noExistsStr 'this is a test'

 

Hash类型

在配置文件中可以通过配置

hash-max-ziplist-entries 512 512字节

hash-max-ziplist-value 64 字段数目

 

Hash相关命令

 

1》HSET:将哈希表key中域field设置成指定的value

 

语法:HSET key field value

 

HSET userInfo1 username 'king'

 

HSET userInfo1 password '123456'

 

HSET userInfo1 email '382771946@qq.com' 

 

HGET userInfo1 username

 

HSET userInfo1 username 'queen'

 

如果哈希表key中field不存在,相当于新建field,设置成功返回1

 

如果哈希表key中field存在,相当于重新赋值,成功返回0

 

2》HGET:返回哈希表key中给定field的值

 

语法:HGET key field

 

HGET userInfo1 username

 

注意:如果key中field不存在,返回的是nil

 

3》HSETNX:将hash表中的field设置成指定的值,只要field不存在的时候才可以成功;如果field存在,操作无效

 

语法:HSETNX key field value

 

HSETNX testHash1 test 'a'

 

4》HMSET:通过将多个field-value设置到hash表key中

 

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

 

HMSET userInfo2 username 'king' password '123' kickname 'smart king' email '382771946@qq.com'

 

HGET userInfo2 username

 

HMSET userInfo2 username 'queen' role 'admin'

 

5》HMGET:一次获得hash表key中多个field的值

 

语法:HMGET key field field

 

注意:如果hash表key中field不存在,会返回nil

 

6》HGETALL:返回hash表key中所有的field和value

 

语法:HGETALL key

 

HGETALL userInfo2

 

7》HKEYS:返回hash中key的所有的field

 

语法:HKEYS key

 

HKEYS userInfo2

 

8》HVALS:返回hash中key中field所有的对应的值

 

语法:HVALS key

 

HVALS userInfo2

 

9》HEXISTS:检测hash中key的field是否存在

 

语法:HEXISTS key field

 

HEXISTS userInfo2 username

 

HEXISTS userInfo2 notExists

 

10》HLEN:返回hash表key中field的数量

 

语法:HLEN key

 

HLEN userInfo2

 

11》HINCRBY:给hash中key的field做增量操作

 

语法:HINCRBY key field increment

 

HSET userInfo3 age 12

 

HINCRBY userInfo3 age 10

 

HSET userInfo3 username 'king'

 

HINCRBY userInfo3 username 10

 

12》HINCRBYFLOAT:给hash中key的field做增量浮点操作

 

语法:HINCRBYFLOAT key field increment

 

HSET userInfo3 salary '123.111'

 

HINCRBYFLOAT userInfo3 salary 12.888

 

13》HDEL:删除hash中key的指定域,可以删除一个也可以删除多个

 

语法:HDEL key field field

 

HGETALL userInfo2

 

HDEL userInfo2 username password email 

 

List类型

 

Set集合类型

 

Zset有序集合类型

 

keys相关的命令:

 

1》KEYS:返回所有符合给定模式的key

 

语法:KEYS pattern

 

*:匹配任意个字符

 

?:匹配一个任意字符

 

[]:匹配[]之间的一个字符,[b-e],a[b-e] ab ac ad ae

 

\x:匹配特殊字符\? \*

 

MSET one 1 two 2 three 3 four 4 five 5 six 6 seven 7

 

KEYS *

 

KEYS *o*

 

KEYS t??

 

KEYS ?o*

 

KEYS c[n-z]*

 

2》EXISTS:检测指定key是否存在

 

语法:EXISTS key

 

EXISTS one

 

3》TYPE:返回key所存储的类型

 

语法:TYPE key

 

不存在的key 返回none

string

hash

set

zset

list

 

TYPE testStr11

 

TYPE userInfo2

 

4》EXPIRE:设置key的过期时间

 

语法:EXPIRE key seconds

 

SET cache_page 'http://phpfamily.org'

 

EXPIRE cache_page 100

 

注意:如果key已经存在过期时间,在通过EXPIRE设置的时候会覆盖之前过期时间

 

5》EXPIREAT:需要指定在指定时间戳过期

 

语法:EXPIREAT key timestamp

 

SET cache_page1 'http://maiziedu.com'

 

EXPIREAT cache_page1 1431868810

 

6》PEXPIRE:以毫秒的形式指定过期时间

 

语法:PEXIRE key milliseconds

 

SET cache_page2 'http://maiziedu.com'

 

PEXPIRE cache_page2 50000

 

7》PEXPIREAT:指定时间戳,单位为毫秒

 

语法:PEXPIREAT key timestamp

 

SET cache_page3 'http://phpfamily.org'

 

PEXPIREAT cache_page3 1431968810000000

 

8》TTL:以秒为单位返回key剩余时间

 

语法:TTL key

 

注意:如果没有key没有设置过期时间,返回-1

 

如果key不存在返回 -2

 

返回过期时间

 

SET cache_page4 'http://www.baidu.com'

 

TTL cache_page4

 

TTL cache_page5

 

EXPIRE cache_page4 100

 

TTL cache_page4

 

9》PTTL:以毫秒为单位返回key的剩余时间

 

语法:PTTL key

 

 

10》PERSIST:将一个带有过期时间的key转变成永久的key

 

语法:PERSIST key

 

SET cache 'testCache'

 

EXPIRE cache 100

 

TTL cache

 

PERSIST cache 

 

TTL cache

 

11》DEL:删除指定的KEY

 

语法:DEL key ...

 

DEL cache

 

12》RANDOMKEY:随机的从当前数据库中返回一个key

 

语法:RANDOMKEY

 

RANDOMKEY

 

13》RENAME:重名名一个键

 

语法:RENAME key newkey

 

SET testRename1 'rename1'

 

RENAME testRename1 testRename2

 

RENAME testRename2 testRename2 

 

RENAME testRename2 test14

 

RENAME test14 six

注意:如果名称没有发生改变会报错

 

14》RENAMENX:必须重命名这个新名称不存在才会生效

 

语法:RENAMENX key newkey

 

SET testRename 'test'

 

RENAMENX testRename six

 

15》DUMP:序列化给定的Key,返回序列化之后的值

 

语法:DUMP key

 

SET testDump 'this is a test'

 

DUMP testDump

 

16》RESTORE:反序列化

 

语法:RESTORE key tt1 value

 

RESTORE testDump1 0 "\x00\x0ethis is a test\x06\x00f\x97\x10\x8bo\xb5\x91\xf8"

 

RESTORE testDump3 50000 "\x00\x04test\x06\x00\x17}\xc7 \x99\xa4\x8c\xd6"

 

17》MOVE:将当前数据库中的key移动到另外的数据库中

 

语法:MOVE key dbId

 

SELECT 0

SET testMove 'aaaa'

 

MOVE testMove 1

 

注意:当移动一个不存在的key会失败

当目录数据库中存在同名key的时候移动失败

 

OBJECT、MIGRATE、SCAN、SORT

 

List列表类型

 

1》LPUSH:向列表左端添加元素

 

语法:LPUSH key value value...

 

LPUSH myList1 a b c

 

2》RPUSH:向列表右端添加元素

 

语法:RPUSH key value ...

 

RPUSH myList1 test1 test2 test3

 

RPUSH myList1 test3 test4

 

3》LPUSHX:向列表头部添加元素,只有key存在在来添加

 

语法:LPUSHX key value 

 

LPUSHX myList2 a 

 

LPUSH myList2 a

 

LPUSHX myList2 b

 

4》RPUSHX:向列表尾部添加元素,只有key存在在来添加

 

语法:RPUSHX key value 

 

5》LPOP:将列表头部的元素弹出

 

语法:LPOP key

 

LPOP myList1

 

6》RPOP;弹出列表尾部的元素

 

语法:RPOP key

 

RPOP myList1

 

7》LLEN:得到列表的长度

 

语法:LLEN key

 

LLEN myList2

 

8》LRANGE:获取列表片段

 

语法:LRANGE key start stop

 

LRANGE myList1 0 -1

 

注意:

如果start下标比列表的最大下标end大,返回的空列表

如果stop比列表长度大,返回到列表的末尾

 

9》LREM:删除列表中指定的值

 

语法:LREM key count value

 

count值有以下几种:

 

count>0:从列表的头开始,向尾部搜索,移除与value相等的元素,移除count个

 

count<=:从列表尾部向头搜索,移除与value相等的元素,移除count个

 

count=0,移除列表中所有与count相等的值

 

LPUSH myList2 a b c d a e b c d b e f b g e b

 

LREM myList2 2 b

 

LREM myList2 -2 a

 

LREM myList2 0 e

 

10》LINDEX:获得指定索引元素的值

 

语法:LINDEX key index

 

LINDEX myList2 3

 

LINDEX myList2 -3

 

 

11》LSET:设置指定索引元素的值

 

语法:LSET key index value

 

LSET myList2 0 king

 

12》LTRIM:只保留列表的片段

 

语法:LTRIM key start stop

 

LPUSH myList3 log11 log22 log33 log44 log55

 

LTRIM myList3 0 1

 

LPUSH myList4 a b c d e f g

 

LTRIM myList4 1 -1

 

LTRIM myList4 1 1000

 

LTRIM myList4 1000 2000 列表被清空

 

LTRIM myList4 3000 2000 列表被清空

 

13》LINSERT:向列表插入元素

 

语法:LINSERT key BEFORE|AFTER pivot value

 

LPUSH myList5  a b c d

 

LINSERT myList5 BEFORE 'b' 'king'

 

LINSERT myList5 BEFORE bb queen

 

LINSERT myList5 AFTER d queen

 

LINSERT myList6 AFTER d queen

 

14》RPOPLPUSH:将元素从一个列表转到另一个列表

 

语法:RPOPLPUSH source destination

 

LPUSH myList6 a b c

 

LPUSH myList7 x y z

 

RPOPLPUSH myList6 myList7

 

LPUSH webLog log1 log2 log3 log4

 

RPOPLPUSH webLog webLog

 

RPOPLPUSH webLog1 webLog

 

15》BLPOP:BLPOP 是LPOP的阻塞版本

 

语法:BLPOP key [key...] timeout

 

LPUSH myList9 a b c

 

LPUSH myList10 d e f

 

BLPOP myList8 myList9 myList10 0

 

BLPOP myList 8 0

 

set集合类型:无序集合

 

1》SADD:向集合中添加元素

 

语法:SADD key member [,...]

 

SADD web maiziedu.com

 

SADD web phpfamily.org jd.com

 

SADD web phpfamily.org taobao.com 

 

2》SMEMBERS:返回指定集合中的元素

 

语法:SMEMBERS key

 

SMEMBERS web 

 

3》SISMEMBER:检测member是否是集合中的成员

 

语法:SISMEMBER key member

 

SISMEMBER web maiziedu.com

 

4》SREM:删除集合中的一个或者多个成员

 

语法:SREM key member [member...]

 

SREM web jd.com

 

SREM web taobao.com phpfamily.org

 

5》SPOP:删除并返回集合中的随机元素

 

语法:SPOP key

 

SADD course php java ios android c c++ oc

 

SPOP course

 

6》SRANDMEMBER:随机返回集合中的元素

 

语法:SRANDMEMBER key count

 

注意:

count为正数,而且小于集合中的元素,返回的一个包含随机元素的集合数组;count数大于集合中元素的个数,这时候会返回整个集合

count为负数,返回一个数组,数组中的成员可能出现重复,数组的长度是count取绝对值

 

SRANDMEMBER course

 

SRANDMEMBER course 2

 

SRANDMEMBER course 50

 

SRANDMEMBER course -2

 

7》SDIFF:返回集合间的差集

 

语法:SDIFF key key ...

 

SADD testSet1 a b c d e

 

SADD testSet2 b c d e f

 

SDIFF testSet1 testSet2

 

SDIFF testSet2 testSet1

 

SADD testSet3 x y z a

 

SDIFF testSet1 testSet2 testSet3

 

8》SINTER:返回集合间的交集

 

语法:SINTER key key...

 

SINTER testSet1 testSet2

 

SINTER testSet1 testSet2 testSet3

 

SADD testSet3 b 

 

9》SUNION:返回集合中并集操作

 

语法:SUNION key key...

 

SUNION testSet1 testSet2

 

SUNION testSet1 testSet2 testSet3

 

10》SCARD:返回集合中元素个数

 

语法:SCARD key

 

SCARD testSet1

 

11》SDIFFSTORE:将差集结果保存到指定集合中

 

语法:SDIFFSTORE destination key key ...

 

SDIFFSTORE diffSet testSet1 testSet2

 

SADD diffSet f 

 

SDIFFSTORE diffSet testSet2 testSet1

 

SDIFFSTORE diffSet testSet1 testSet2

 

SDIFFSTORE testSet1 testSet1 testSet2

 

12》SINTERSTORE:将交集的结果保存在指定集合中

 

语法:SINTERSTORE destination key key ...

 

13》SUNIONSTORE:将并集的结果保存到指定集合中

 

语法:SUNIONSTORE destination key key ...

 

14》SMOVE:将集合中元素移动另外一个集合中

 

语法:SMOVE source destination member

 

注意:原子操作

 

SMOVE testSet2 testSet1 f

 

SADD testSet2 f

 

SMOVE testSet2 testSet1 f

 

zset(sorted set)有序集合

 

1》ZADD:将元素及其分数添加到集合中

 

语法:ZADD key score member [score member]

 

ZADD PHPScore 100 king 

 

ZADD PHPScore 98 queen 98 maizi 80 test 78 test1 85 test2

 

ZADD PHPScore 60 test2 67 test3 56 test4

 

ZADD PHPScore +inf maxInt -inf minInx

 

2》ZSCORE:获得指定元素的分数

 

语法:ZSCORE key member

 

ZSCORE PHPScore maizi

 

ZADD PHPScore 12.3 test5 

 

3》ZRANGE:按照元素分数从小到大的顺序返回指定索引start到stop之间所有元素(包含两端)

 

语法:ZRANGE key start stop [WITHSCORES]

 

ZRANGE PHPScore 0 -1

 

ZRANGE PHPScore 0 -1 WITHSCORES

 

ZRANGE PHPScore 0 2 WITHSCORES

 

ZRANGE PHPScore 0 2000 WITHSCORES

 

ZRANGE PHPScore 1000 2000 WITHSCORES

 

ZADD PHPScore 60 test6 60 test7 60 test8 60 test9

 

注意:当两个元素的分数相同的时候,Redis在排序按照字典的顺序(0<9<A<Z<a<z),如果使用的是UTF-8

的编码方式的中文同样按照字典顺序排列

 

4》ZREVRANGE:和ZRANGE相反,按照分数从大到小的顺序

 

语法:ZREVRANGE key start stop [WITHSCORES]

 

ZREVRANGE PHPScore 0 -1 WITHSCORES

 

5》ZRANGEBYSCORE:获得指定分数范围内的元素,按照分数从小到大的顺序,返回的是分数在指定的min到max的元素

 

语法:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]

 

#获得分数80~90之间的所有元素

 

ZRANGEBYSCORE PHPScore 80 90

 

ZADD PHPScore 81 test9 82 test10 83 test11 84 test12 84 test13 88 test14 89 test15

 

ZRANGEBYSCORE PHPScore 80 90 WITHSCORES

 

ZADD PHPScore 90 test16

 

ZRANGEBYSCORE PHPScore 80 (90 WITHSCORES

 

ZRANGEBYSCORE PHPScore (80 (90 WITHSCORES

 

注意:通过(代表不包端点

 

ZRANGEBYSCORE PHPScore 90 +inf WITHSCORES

 

ZRANGEBYSCORE PHPScore 80 +inf WITHSCORES LIMIT 0 3

 

6》ZREVRANGEBYSCORE:获得指定分数范围内的元素,按照元素的分数从大到小的顺序返回min和max之间的元素

 

语法:ZREVRANGEBYSCORE key max min [WITHSCORES] [LIMIT offset count]

 

ZREVRANGEBYSCORE PHPScore 90 80 WITHSCORES

 

7》ZINCRBY:操作某个元素的分数,返回操作之后的分数

 

语法:ZINCRBY key increment member

 

ZINCRBY PHPScore 5 test16

 

ZINCRBY PHPScore -15 test16

 

8》ZCARD:获得集合中元素的数量

 

语法:ZCARD key

 

ZCARD PHPScore

 

9》ZCONUT:获得指定分数内的元素的数量

 

语法:ZCOUNT key min max

 

ZCOUNT PHPScore 80 90

 

10》ZREM:删除一个或者多个元素,返回删除元素的个数

 

语法:ZREM key member ...

 

ZREM PHPScore test16

 

11》ZREMRANGEBYRANK:按照排名范围删除元素,按照分数从小到大的顺序删除所指定的排名范围内的所有元素

 

语法:ZREMRANGEBYRANK key start stop

 

ZADD testRem 1 a 2 b 3 c 4 d 5 e 6 f 7 g 8 h

 

ZREMRANGEBYRANK testRem 0 2

 

12》ZREMRANGEBYSCORE:按照分数范围删除元素

 

语法:ZREMRANGEBYSCORE key min max

 

ZADD testRem1 1 a 2 b 3 c 4 d 5 e 6 f 7 g 8 h

 

ZREMRANGEBYSCORE testRem1 3 7

 

13》ZRANK:获得指定元素的排名,根据分数从小到大的顺序

 

语法:ZRANK key member

 

ZRANK PHPScore king

 

14》ZREVRANK:获得指定元素的排名,根据分数从大到小的顺序

 

语法:ZREVRANK key member

 

ZREVRANK PHPScore king

 

15》ZINTERSTORE:计算有序集合的交集,并将结果保存起来

 

语法:ZINTERSTORE destination numkeys [WEIGHTS weight weight...] [AGGREGATE SUM | MIN | MAX]

 

ZADD testSortedSet1 1 a 2 b 3 c

 

ZADD testSortedSet2 10 a 20 b 30 c

 

ZINTERSTORE resTestSorted1 2  testSortedSet1 testSortedSet2

 

ZINTERSTORE resTestSorted2 2  testSortedSet2 testSortedSet2 AGGREGATE SUM

 

ZINTERSTORE resTestSorted3 2  testSortedSet1 testSortedSet2 AGGREGATE MIN

 

ZINTERSTORE resTestSorted4 2  testSortedSet1 testSortedSet2 AGGREGATE MAX

 

ZINTERSTORE resTestSorted5 2 testSortedSet1 testSortedSet2 WEIGHTS 2 0.2

 

16》ZUNIONSTORE:计算有序集合并集,将结果保存起来

 

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

 

ZADD TESTUNIONSET1 1 a 2 b 3 c

 

ZADD TESTUNIONSET2 4 d 5 e 6 f 7 a

 

ZUNIONSTORE uniRes1 2  TESTUNIONSET1 TESTUNIONSET2

 

ZUNIONSTORE uniRes2 2  TESTUNIONSET1 TESTUNIONSET2 AGGREGATE SUM

 

ZUNIONSTORE uniRes3 2  TESTUNIONSET1 TESTUNIONSET2 AGGREGATE MIN

 

ZUNIONSTORE uniRes4 2  TESTUNIONSET1 TESTUNIONSET2 AGGREGATE MAX

 

ZUNIONSTORE uniRes5 2  TESTUNIONSET1 TESTUNIONSET2  WEIGHTS 2 2

分享到:
评论

相关推荐

    【Redis基础教程及开发案例及解析】Redis基础教程及开发案例及解析

    Redis基础教程及开发案例及解析Redis基础教程及开发案例及解析Redis基础教程及开发案例及解析Redis基础教程及开发案例及解析Redis基础教程及开发案例及解析Redis基础教程及开发案例及解析Redis基础教程及开发案例及...

    redis基础知识培训

    本文档从redis基础知识,复制模式,集群模式等介绍redis基础知识,介绍了数据槽,分片,key等知识。

    redis基础入门

    ### Redis基础入门知识点详解 #### 一、Redis简介与特性 Redis是一种开源的高性能键值存储系统,它支持多种数据结构如字符串(Strings)、哈希(Hashes)、列表(Lists)、集合(Sets)以及有序集合(Sorted Sets)等。与...

    Redis基础.md

    # Redis基础 ## 数据类型 ### strings * `set key value`和`get key`,注意set操作会覆盖已有的key/value,若不希望覆盖可使用`set key value nx` * `mset key1 value1 key2 value2 ...`和`mget key1 key2 ...`...

    v1 动力节点redis基础

    【Redis基础】Redis是一款高效的Key-Value型NoSQL数据库,由Antirez开发,以其内存存储、持久化和丰富的数据结构而闻名。Redis不遵循传统的SQL规范,而是提供了一套独特的命令来操作各种数据结构,如字符串(Strings)...

    Redis基础资料,基础整理

    Redis 基础资料,基础整理 Redis 是一种 key-value 存储系统,具有跨平台和非关系型数据库的特点。它可以存储多种类型的数据,包括字符串、哈希、列表、集合和有序集合等。Redis 的特点包括数据持久化、备份、丰富...

    Redis基础数据库类型

    Redis 基础数据类型 Redis 作为一个内存数据库已经被许许多多的公司使用,它的性能非常的优秀,读写速度支持非常快而且支持 10W 的 QPS。今天我们就来学习下它的丰富的数据类型。 String(字符串) 字符串类型是 ...

    v2 动力节点redis基础

    【Redis基础知识】 Redis,全称为Remote Dictionary Server,是一款开源的、基于内存的、高性能的NoSQL数据库。它采用键值对(Key-Value)数据结构,同时也支持多种其他数据结构如列表(List)、集合(Set)、有序...

    Redis 基础.zip

    Redis 基础 用于构建松散耦合的分布式应用程序的可插入基础块。缓存队列锁消息传递工作文件存储指标包括 Redis、Azure、AWS、RabbitMQ、Kafka 和内存中的实现(用于开发)。为什么选择 Foundatio?在构建几个大型云...

    redis基础知识-参考

    Redis 基础知识 Redis 是一个基于 key-value 键值的持久化数据库存储系统。它支持的数据存储类型更丰富,并且持久化存储,还支持主从同步,这点类似于 MySQL。Redis 的应用场景非常广泛,以下是 Redis 的基础知识点...

    redis基础介绍.pptx

    redis的简单ppt,东西不多.之前有次开会做的,希望有用

    redis基础命令讲解

    同时,提供的"redis基础命令讲解.pdf"和"项目说明.pdf"文档将提供更详细的解释和示例,有助于深化理解。学习Redis不仅是掌握其命令,还需要理解其在实际应用中的性能优势和最佳实践。例如,如何利用Redis实现高效的...

    2024最新Redis基础HM

    ### 2024最新Redis基础知识详解 #### 1. Redis简介 Redis是一个基于内存的键值对(Key-Value)存储系统,以其卓越的性能和丰富的数据结构而闻名于世。由于其主要存储在内存中,因此拥有极高的读写速度。这种特性...

    Redis基础笔记总结

    ### Redis基础笔记总结 #### 一、Redis入门概述 ##### 1.1 Redis是什么 - **定义**: Remote Dictionary Server(远程字典服务器)是一种开源的、高性能的键值(Key-Value)数据库。 - **语言**: 使用ANSI C语言...

    springBoot+mysql+redis基础项目

    【标题】"springBoot+mysql+redis基础项目"是一个适合初学者入门的IT项目,它结合了Spring Boot、MySQL和Redis三个关键组件,构建了一个基本的后端数据处理框架。这个项目的核心目标是帮助新手理解如何在实际开发中...

    redis基础知识,狂神说java

    【Redis基础知识】 Redis 是一款高性能的键值存储系统,常用于缓存和数据库功能。它的全称是 Remote Dictionary Server,由 Antirez 开发。Redis 支持多种数据结构,如 String、List、Set、Hash 和 Zset,以及一些...

    redis基础使用说明文档

    以下是对Redis基础使用的详细介绍: 1. **安装与启动** - Redis通常通过源码编译或预编译二进制包进行安装。在Linux环境下,下载源码后,执行`make`和`make install`即可。 - 安装完成后,启动Redis服务使用`...

    redis基础培训.pptx.zip

    在Redis基础培训中,我们通常会涵盖以下几个关键知识点: 1. **Redis简介**:Redis是一个开源(BSD许可),内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。它的特点是数据持久化,支持多种数据...

    Redis基础知识详解

    ### Redis基础知识详解 #### 一、NoSQL概述 ##### 1.1 什么是NoSQL? NoSQL,全称为Not Only SQL,是指一类非关系型数据库管理系统。与传统的SQL(Structured Query Language)数据库不同,NoSQL数据库更加注重...

    redis基础部分的笔记

    **Redis基础部分笔记** Redis(Remote Dictionary Server)是一款开源、高性能、无模式的键值对存储系统,常用于数据缓存、消息队列以及数据库功能。以下是对Redis基础知识的详细阐述: 1. **Redis的数据类型** -...

Global site tag (gtag.js) - Google Analytics