Redis-string类型操作命令
APPEND key value
如果key已经存在,并且为字符串,那么这个命令会把value追加到原来值的末尾。如果key不存在,首先创建一个空字符串,再执行追加操作。
返回值:返回APPEND后字符串的长度。
EXISTS mykey0APPEND mykey "Hello"5APPEND mykey " world"11GET mykeyHello world
SETBIT
SETBIT key offset value
对key所存储的字符串值,设置或清除指定偏移量上的位(bit)。
位的设置或清除取决于value参数。
当key不存在时,自动生成一个新的字符串值。
SETBIT bit 1008610SETBIT bit 1008611GETBIT bit 100861GETBIT bit 1000
BITCOUNT
BITCOUNT key [start] [end]
计算给定字符串中,被设置为1 的比特位的数量。对于不存在的字符串,BITCOUNNT操作返回0。
返回值:被设置为1的位的数量。
BITCOUNT bits0SETBIT bits 010BITCOUNT bits1SETBIT bits 310BITCOUNT bits2
- 模式:使用bitmap实现用户上线次数统计
可以使用SETBIT key为网站上线的天数,value为1,来确定用户在某天在线,从而统计出用户的上线天数。如设置Peter在第101天在线,则可以使用:
SETBIT peter 1011
依次类推。最后统计即可获取用户在线天数。
GETBIT key offset
对key所存储的字符串值,获取指定偏移量上的位。
当offset比字符串的长度大,或者key不存在时,返回0。
EXISTS bit0GETBIT bit 100860SETBIT bit 410GETBIT bit 41
DECR
将key中存储的数字值减一。
如果key不存在,那么会初始化key值为0,然后惊醒DECR操作。操作限制在64位有符号数字内,
返回值:执行DECR命令后的key值。
SET num 10OKDECR num9EXISTS count0DECR count-1
DECRBY key decrement
将key所存储的值减去减量decrement。
如果key不存在,则先被初始化为0,然后再执行操作。如果值包含错误的类型,则会返回一个错误。
返回值:操作后的值。
SET count 10OKDECRBY count 20-10EXISTS pages0DECRBY pages 1-1DECRBY pages -10DECRBY pages -33
GET key
返回key所关联的字符串的值。如果key不存在,则返回nil。
返回值:key不存在时,返回nil,否则返回key的值。
如果key不是字符串类型,则返回一个错误。
GET dbSET DB redisOKget DBredisDEL db0EXISTS db0LPUSH db redis mongodb mysql3GET dbERR Operation against a key holding the wrong kind of value
GETRANGE key start end
返回字符串值的字串。start end指定截取范围(包括start end在内)。负数表示从最后开始计数。
返回值:截取的子串。
SET greeting "Hello,my friend"OKGETRANGE greeting 04HelloGETRANGE greeting -1-5GETRANGE greeting -3-1endGETRANGE greeting 0-1Hello,my friendGETRANGE greeting 010000000Hello,my friend
GETSET key value
将给定key的值设为value,并返回key的旧值。
当key存在但不是字符串时,返回一个错误。
返回值:返回给定key的旧值。
当key没有旧值,即key不存在时,返回nil。
GETSET db mongodbGET dbmongodbGETSET db redismongodb
模式:GETSET和INCR组合使用,实现获取一个原子性操作的执行计数器结果,并对结果进行复位。
INCR mycount1INCR mycount2INCR mycount3GETSET mycount 03
INCR key
将key中存储的数字值增一。
如果key不存在,那么key会被初始化0,再执行INCR操作。
如果包含错误的数据类型,则会返回一个错误。
返回值:执行INCR操作后key的值。
SET page_view 20OKINCR page_view21
模式:计数器
INCRBY key increment
将key所存储的值增加增量increment。
如果key不存在,那么key的值会先被初始化为0,再执行INCRBY操作。
SET rank 50OKINCRBY rank 2070GET rank70SET book "REDIS"OKINCRBY book 1ERR value is not an integer or out of range
INCRBYFLOAT key increment
为key中所存储的 值加上浮点数的增量increment。无论加法计算所得的浮点数的实际精度有多长,
INCRBYFLOAT 的计算结果也最多只能表示小数点的后十七位。
返回值:执行之后key的值。
SET mykey 10.50OKINCRBYFLOAT mykey 0.110.6SET mykey 314e-2OKINCRBYFLOAT mykey 0.53.64SET mykey 4OKINCRBYFLOAT mykey 0.54.5
MGET key[key...]
返回所所有给定key的值。
如果给定key里面,某个key不存在,则这个key返回特殊值nil。该命令永不失败。
返回值:一个包含所有给定key的值的列表。
SET redis redis.comOKSET mongodb mongodb.comOKMGET redis mongodb mysqlredis.commongodb.com
MSET key value[key value]
同时设置一个或多个key-value对。
如果某个给定key存在,那么覆盖原有值。如果不希望被覆盖,可以使用MSENX命令。
MSET是一个原子操作,所有给定的key都会在同一时间被设置。
返回值:总是返回OK。
MSET date "2012-05" time "11:00 am" weather "SUNNY"OKMGET date time weather2012-0511:00 amSUNNYSET google "google.hk"OKMSET google "google.com"OKGET googlegoogle.com
MSETNX key value[key value ...]
同时设置多个key-value,当且仅当所有给定key都不存在。如果有一个key存在,那么MSETNX操作会拒绝执行所有给定的key。
MSETNX是原子操作,所有字段要么成功,要么失败。
返回值:所有key成功,返回1。失败返回0。
MSETNX rmdbs "MySql" nosql "MongoDB" key-value-store "Redis"1MGET rmdbs nosqlMySqlMongoDBMSETNX rmdbs "MySql" language "Java"0
PSETEX key milliseconds value
已milliseconds毫秒为单位,设置key的生存时间。
返回值:成功返回OK。
PSETEX mykey 10000"HELLO"OKPTTL mykey7110GET mykeyHELLOPTTL mykey-1GET mykey
SET key value [EX seconds] [PX milliseconds] [NX] [NX]
将字符串value关联到key。
如果key已经持有其他值,SET操作覆盖旧值。
对于某个原本都有生存时间TTL的键来说,当SET命令成功在执行时,原TTL会被清除。
可选参数:
- EX seconds:设置键的国企时间为second秒。此参数等同于SETEX key second value。
- PX millisecond:设置键的过期时间为millisecond毫秒。
SET key value PX millisecond效果等同于PSETEX key millisecond value。 - NX:只在key不存在时,才对key执行操作。set key value NX 等同于: SETNX key value。
- XX:只在键已经存在时,才进行操作。
SET key "value"OKGET keyvalueSET key "new-value"OKget keynew-valueSET key "hello" EX 100860OKTTL key100856TTL key100852SET key "moto" PX 123331OKTTL key121get keymotoTTL key107SET key "value" NXSET key1 "value" NXOKSET key "value" XXOKSET key2 "value" XX
SETEX key seconds value
将value关联到key,并将key的生存时间设置为seconds秒。
如果key已经存在,SETEX将会覆盖旧值。
返回值:设置成功时返回OK。蛋seconds参数不合法时,返回一个错误。
SETEX user_id 6010086OKTTL user_id54get user_id10086get user_id10086TTL user_id36
SETNX key value
将key的值设为value,当且仅当key不存在。
若给定的key已经存在,则SETNX不做任何动作。SETNX 是 SET if Not eXists。
返回值:成功1,失败0。
EXISTS job0SETNX job "code-farmer"1SETNX job "programmer"0GET jobcode-farmer
SETRANGE key offset value
用value参数overwrite给定key所存储的字符串,从offset开始。
不存在的key当做空白字符串处理。
SETRANGE命令会确保字符串足够长以便将value设置在指定的便宜量上。如果字符串长度比偏移量小,则空白处使用零字节(\x00)填充。
使用的最大偏移量为2^29 - 1。
返回值:修改后的字符串长度。
redis> SET greeting "hello world"OKredis> SETRANGE greeting 6"Redis"(integer)11redis> GET greeting"hello Redis"# 对空字符串/不存在的 key 进行 SETRANGEredis> EXISTS empty_string(integer)0redis> SETRANGE empty_string 5"Redis!"# 对不存在的 key 使用 SETRANGE(integer)11redis> GET empty_string # 空白处被"\x00"填充"\x00\x00\x00\x00\x00Redis!"
STRLEN key
返回字符串的长度。当key不是一个字符串时,返回一个错误。
返回值: 字符串长度。当key不存在时,返回0。
SET mykey "Hello World"OKSTRLEN mykey11STRLEN nonestr0
------------
以上为Redis中对string类型的基本操作命令。
本文主要参考:http://redisdoc.com/
欢迎转载,但转载请注明原文链接[博客园: http://www.cnblogs.com/jingLongJun/]
[CSDN博客:http://blog.csdn.net/mergades]。
如相关博文涉及到版权问题,请联系本人。
[CSDN博客:http://blog.csdn.net/mergades]。
如相关博文涉及到版权问题,请联系本人。

浙公网安备 33010602011771号