Redis是一个数据结构类型的服务器,不是单纯的key-value存储。Redis里面的键是二进制安全的(二进制安全是指数据在传输过程中保证数据的安全性,包括加密等),因此键的内容不应该包含空格或者换行符。比如”hello world”和”hello world\n”是错误的。
一 Keys上的操作
1) DEL key [key...] 删除多个key,不存在的key,则忽略 返回实际删除了的key的个数2) EXISTS key 返回1和0表示key是否存在3) EXPIRE key seconds 设置key的存活时间4) EXPIREAT key timestamp UNIX timestamp(seconds since January 1, 1970)来设置存活期5) KEYS pattern 返回match pattern的keys的列表6) MOVE key db 在当前数据库中将key移动到指定的db中 如果key在当前db中不存在或者指定的db中已有这个key,就不移动 返回1或者0表示是否moved7) OBJECT REFCOUNT <key> 返回关联到key上的引用的个数 OBJECT ENCODING <key> 返回key在数据库内部的压缩编码方式 OBJECT IDLETIME <key> 返回key多久没有被读写 在2.2.3版本后才可使用,目前装的是2.0.2版本,不支持8) PERSIST key 移除key上的时间限制属性,使其永久存在 版本2.1.2后有效9) RANDOMKEY 从数据库随机的返回一个key10) RENAME key newkey 重新命名一个key,其他不变11) RENAMENX key newkey 重新命名一个key,如果newkey已经存在时,命令失败12)SORT key [BY pattern] [LIMIT offset count] [GET pattern [GET pattern ...]] [ASC|DESC] [ALPHA] [STORE destination] 各种排序方式13) TTL key 返回一个key还能在数据库中存活多久(seconds) 如果key不存在或者没有时间限制,返回-1 expire mykey可以设置一个key的存活时间14) TYPE key 返回key的类型(string,list,set...)二 Strings
这是最简单的redis数据类型,在只使用这个数据类型的时候,Redis就和一个有持久存储功能的memcached服务器类似。在Redis中,值最大可以有1GB,因此可以将图片等内容都缓存进去。SET操作,GET操作是基本的存储和读取操作,INCR命令可以将值自增1.
1) APPEND key value 如果key不存在,创建一个新的key 如果key已经存在,在value后apend,改变了value的值2) DECR key key减1,对整型适用(或者以整型代表的字符串) 对其他类型,返回错误3) DECRBY key decrement 将key减少指定的这么多 如果key不存在,从零开始减少4) GET key 不解释5) GETRANGE key start end 返回substring,包含开始和结束索引 0代表第一个索引,-1最后一个索引6) GETSET key value 对已经存在的key,设置其新的value,并返回老的value 如果key不是string类型,返回错误7) INCR key 增加,同上8) INCRBY key increment 同上,不解释9) MGET key [key ...] 返回多个值10) MSET key value [key value ...] 同时设置多个key-value的值11) MSETNX key value [key value ...] 当有一个key已经存在时,整条命令都不执行12) SET key value 不解释13) SETEX key seconds value 设置一个key并为它设置时间 等同于下列命令: SET mykey value EXPIRE mykey seconds 14) SETNX key value SET if Not eXists,当key不存在时设置一个新的key 否则,什么也不做15) SETRANGE key offset value 从已存在key的offeset索引处用value代替以前的值 版本2.1.8后有效16) STRLEN key 不解释三 HashesRedis的hash是string类型的field和value映射表,添加删除的时间复杂度是O(1)。适合用来存储对象,可以减少内存的使用。减少内存使用的原因是新建hash对象时开始使用zipmap来存储。
1) HDEL key field [field ...] 删除hash表(key)中的多个域 对不存在的域忽略,返回实际删除的域的个数2) HEXISTS key field hash表(key)中是否存在域field3) HGET key field 从hash表中得到域field的值4) HGETALL key 返回hash表中的所有域和它对应的值5) HINCRBY key field increment 将hash表中指定域增加一个值6) HKEYS key 返回所有的域7) HLEN key 返回hash表的长度8) HMGET key field [field ...] 返回hash表多个域的值9) HMSET key field value [field value ...] 同上10) HSET key field value 设置一对值11) HSETNX key field value 仅当域不存在时设置12) HVALS key 返回所有的values四 ListsRedis的List类型是使用双向链表存储的,因此不管是在List的头还是尾部插入数据,所消耗的时间的是固定的。
1) BLPOP key [key ...] timeout Remove and get the first element in a list, or block until one is available Lpop的blocking版本,在timeout时间时间内,pop第一个非空的key中的第一个元素(元素连同它所在的key一起返回) 可以允许key中有空值,它会去找第一个非空的key 如果都空,blocking发生作用,它会等待直到有一个key经过了lpush或rpush非空2) BRPOP key [key ...] timeout Remove and get the last element in a list, or block until one is available 最后一个。同上3) BRPOPLPUSH source destination timeout Pop a value from a list, push it to another list and return it; or block until one is available4) LINDEX key index 用索引获取值(后进列表的索引在前)5) LINSERT key BEFORE|AFTER pivot value 将value插入在pivot之前或者之后6) LLEN key 不解释7) LPOP key pop并返回第一个值(索引0的值)8) LPUSH key value [value ...] 不解释9) LPUSHX key value 同上一条的区别是,只有当key已经存在并非空时,才push一个value10) LRANGE key start stop 返回索引从start到stop的值11) LREM key count value 删除|count|个value,count为正表示从左往右数,为负表示从右往左数 0表示删除全部值为value的项 返回值是实际删除的个数12) LSET key index value 要设置的index范围必须已存在13) LTRIM key start stop trim一个list,保留start到stop之间的14) RPOP key pop最后一个key15) RPOPLPUSH source destination pop最后一个元素,append到另一个list里,并返回这个值16) RPUSH key value [value ...] 加到列表最后17) RPUSHX key value 仅当列表已经非空时,加到列表最后五 SetsRedis的SETs是没有排序的二进制字符串集,换种说法就是字符串的无序集合。因为它是通过哈希表来实现的,因此它的添加,删除,查找的时间复杂度都是O(1)。Set除了基本的添加删除操作之外,还存在集合的取并集,交集,差集。通过这些操作可以轻松实现SNS和BLOG的好友推荐,标签等功能。
1) SADD key member 如果member已存在,命令失效. 注意是集合,元素不能重复2) SCARD key 返回集合中元素的个数3) SDIFF key [key ...] 差集,在第一个集合中存在,但在其他集合中都不存在的元素4) SDIFFSTORE destination key [key ...] 同上,只是将返回的集合存在集合 destination中5) SINTER key [key ...] 交集6) SINTERSTORE destination key [key ...] 同上7) SISMEMBER key member 是否属于一个集合8) SMEMBERS key 返回集合所有元素9) SMOVE source destination member 从一个set里将元素移动到另一个set里10) SPOP key pop一个随进的元素,因为集合是无序的11) SRANDMEMBER key 返回一个随机的元素12) SREM key member [member ...] 移除一个或多个元素 不在的元素忽略13) SUNION key [key ...] 并集14) SUNIONSTORE destination key [key ...] 同上六 Sorted Sets和set一样是字符串的集合,不同的是每个元素都会关联一个double类型的score。实现使用的是skip list和hash table,skip list的实现使用的是双线链表。Score的主要作用是排序,因此 sorted set主要用作索引。
1) ZADD key score member [score] [member] 增加一个或多个元素,如果该元素已经存在,更新它的socre值 虽然有序集合有序,但它也是集合,不能重复元素,添加重复元素只会 更新原有元素的score值2) ZCARD key 元素个数3) ZCOUNT key min max SCORE值在min和max之间的元素的个数4) ZINCRBY key increment member 给有序集合key里面的元素member增加increment 若key不存在,创建一个key 若member不存在,创建一个member,从0开始增加 仅当key存在但类型不是有序集合时,出错5) ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX] nubberkeys指定要求交集的集合的个数 将nubberkeys个集合求交集,结果放在集合destination中 (如果des已存在,覆盖它) 参数[WEIGHTS weight [weight ...]] 指定求交集集合的权重,在计算新的score时使用 参数[AGGREGATE SUM|MIN|MAX] 当两个集合中有同一个名字的元素,但score不同时,指定取哪一个score 的元素6) ZRANGE key start stop [WITHSCORES] 索引start到stop处的元素7) ZRANGEBYSCORE key min max [WITHSCORES] score在min到max之间的元素8) ZRANK key member 返回menber的索引(score从低到高升序排列)9) ZREM key member [member ...] 不解释10) ZREMRANGEBYRANK key start stop 不解释11) ZREMRANGEBYSCORE key min max 不解释12) ZREVRANGE key start stop [WITHSCORES] 返回索引之间的元素13) ZREVRANGEBYSCORE key max min [WITHSCORES]同上,返回score区间内的14) ZREVRANK key member 同8),score降序15) ZSCORE key member 不解释16) ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX] 求并集,其他同5)求交集基本KEY操作:
Java代码exits key //测试指定key是否存在,返回1表示存在,0不存在
del key1 key2 ....keyN //删除给定key,返回删除key的数目,0表示给定key都不存在
type key //返回给定key的value类型。返回 none 表示不存在key,string字符类型,list 链表类型 set 无序集合类型...
keys pattern //返回匹配指定模式的所有key,下面给个例子
randomkey //返回从当前数据库中随机选择的一个key,如果当前数据库是空的,返回空串
rename oldkey newkey //原子的重命名一个key,如果newkey存在,将会被覆盖,返回1表示成功,0失败。可能是oldkey不存在或者和newkey相同
renamenx oldkey newkey //同上,但是如果newkey存在返回失败
dbsize //返回当前数据库的key数量
expire key seconds //为key指定过期时间,单位是秒。返回1成功,0表示key已经设置过过期时间或者不存在
ttl key //返回设置过过期时间的key的剩余过期秒数 -1表示key不存在或者没有设置过过期时间
select db-index //通过索引选择数据库,默认连接的数据库所有是0,默认数据库数是16个。返回1表示成功,0失败
move key db-index //将key从当前数据库移动到指定数据库。返回1成功。0 如果key不存在,或者已经在指定数据库中
flushdb //删除当前数据库中所有key,此方法不会失败。慎用
flushall //删除所有数据库中的所有key,此方法不会失败。更加慎用
String操作
Java代码set key value //设置key对应的值为string类型的value,返回1表示成功,0失败
setnx key value //同上,如果key已经存在,返回0 。nx 是not exist的意思
get key //获取key对应的string值,如果key不存在返回nil
getset key value //原子的设置key的值,并返回key的旧值。如果key不存在返回nil
mget key1 key2 ... keyN //一次获取多个key的值,如果对应key不存在,则对应返回nil。下面是个实验,首先清空当前数据库,然后设置k1,k2.获取时k3对应返回nil
mset key1 value1 ... keyN valueN //一次设置多个key的值,成功返回1表示所有的值都设置了,失败返回0表示没有任何值被设置
msetnx key1 value1 ... keyN valueN //同上,但是不会覆盖已经存在的key
incr key //对key的值做加加操作,并返回新的值。注意incr一个不是int的value会返回错误,incr一个不存在的key,则设置key为1
decr key //同上,但是做的是减减操作,decr一个不存在key,则设置key为-1
incrby key integer //同incr,加指定值 ,key不存在时候会设置key,并认为原来的value是 0
decrby key integer //同decr,减指定值。decrby完全是为了可读性,我们完全可以通过incrby一个负值来实现同样效果,反之一样。
append key value //给指定key的字符串值追加value,返回新字符串值的长度。下面给个例子
substr key start end //返回截取过的key的字符串值,注意并不修改key的值。下标是从0开始的,接着上面例子
List操作
Java代码lpush key string //在key对应list的头部添加字符串元素,返回1表示成功,0表示key存在且不是list类型
rpush key string //同上,在尾部添加
llen key //返回key对应list的长度,key不存在返回0,如果key对应类型不是list返回错误
lrange key start end //返回指定区间内的元素,下标从0开始,负值表示从后面计算,-1表示倒数第一个元素 ,key不存在返回空列表
ltrim key start end //截取list,保留指定区间内元素,成功返回1,key不存在返回错误
lset key index value //设置list中指定下标的元素值,成功返回1,key或者下标不存在返回错误
lrem key count value //从key对应list中删除count个和value相同的元素。count为0时候删除全部
lpop key //从list的头部删除元素,并返回删除元素。如果key对应list不存在或者是空返回nil,如果key对应值不是list返回错误
rpop //同上,但是从尾部删除
blpop key1...keyN timeout //从左到右扫描返回对第一个非空list进行lpop操作并返回,比如blpop list1 list2 list3 0 ,如果list不存在list2,list3都是非空则对list2做lpop并返回从list2中删除的元素。如果所有的list都是空或不存在,则会阻塞timeout秒,timeout为0表示一直阻塞。当阻塞时,如果有client对key1...keyN中的任意key进行push操作,则第一在这个key上被阻塞的client会立即返回。如果超时发生,则返回nil。有点像unix的select或者poll
brpop //同blpop,一个是从头部删除一个是从尾部删除
rpoplpush srckey destkey //从srckey对应list的尾部移除元素并添加到destkey对应list的头部,最后返回被移除的元素值,整个操作是原子的.如果srckey是空或者不存在返回nil
Set操作
Java代码sadd key member //添加一个string元素到,key对应的set集合中,成功返回1,如果元素以及在集合中返回0,key对应的set不存在返回错误
srem key member //从key对应set中移除给定元素,成功返回1,如果member在集合中不存在或者key不存在返回0,如果key对应的不是set类型的值返回错误
spop key //删除并返回key对应set中随机的一个元素,如果set是空或者key不存在返回nil
srandmember key //同spop,随机取set中的一个元素,但是不删除元素
smove srckey dstkey member //从srckey对应set中移除member并添加到dstkey对应set中,整个操作是原子的。成功返回1,如果member在srckey中不存在返回0,如果key不是set类型返回错误
scard key //返回set的元素个数,如果set是空或者key不存在返回0
sismember key member //判断member是否在set中,存在返回1,0表示不存在或者key不存在
sinter key1 key2...keyN //返回所有给定key的交集
sinterstore dstkey key1...keyN //同sinter,但是会同时将交集存到dstkey下
sunion key1 key2...keyN //返回所有给定key的并集
sunionstore dstkey key1...keyN //同sunion,并同时保存并集到dstkey下
sdiff key1 key2...keyN //返回所有给定key的差集
sdiffstore dstkey key1...keyN //同sdiff,并同时保存差集到dstkey下
smembers key //返回key对应set的所有元素,结果是无序的
SortedSet操作
Java代码zadd key score member //添加元素到集合,元素在集合中存在则更新对应score
zrem key member //删除指定元素,1表示成功,如果元素不存在返回0
zincrby key incr member //增加对应member的score值,然后移动元素并保持skip list保持有序。返回更新后的score值
zrank key member //返回指定元素在集合中的排名(下标),集合中元素是按score从小到大排序的
zrevrank key member //同上,但是集合中元素是按score从大到小排序
zrange key start end //类似lrange操作从集合中去指定区间的元素。返回的是有序结果
zrevrange key start end //同上,返回结果是按score逆序的
zrangebyscore key min max //返回集合中score在给定区间的元素
zcount key min max //返回集合中score在给定区间的数量
zcard key //返回集合中元素个数
zscore key element //返回给定元素对应的score
zremrangebyrank key min max //删除集合中排名在给定区间的元素
zremrangebyscore key min max //删除集合中score在给定区间的元素
Hash操作
Java代码hset key field value //设置hash field为指定值,如果key不存在,则先创建
hget key field //获取指定的hash field
hmget key filed1....fieldN //获取全部指定的hash filed
hmset key filed1 value1 ... filedN valueN //同时设置hash的多个field
hincrby key field integer //将指定的hash filed 加上给定值
hexists key field //测试指定field是否存在
hdel key field //删除指定的hash field
hlen key //返回指定hash的field数量
hkeys key //返回hash的所有field
hvals key //返回hash的所有value
hgetall //返回hash的所有filed和value
转载初处:keshion.iteye.com/blog/1294851