Home >Database >Mysql Tutorial >redis学习笔记

redis学习笔记

WBOY
WBOYOriginal
2016-06-07 16:12:32941browse

一、几种数据结构: 1、String:key-value (1)添加:set key value/setnx key value(不存在时才添加,已存在返回0)/setex key time value(添加并设置有效时间)/setrange key index value(将key对应的值从index位置开始替换为value)/mset key1 value1 key2 v

一、几种数据结构:

 

1、String:key->value 

 

(1)添加:set key value/setnx key value(不存在时才添加,已存在返回0)/setex key time value(添加并设置有效时间)/setrange key index value(将key对应的值从index位置开始替换为value)/mset key1 value1 key2 value2(一次设置多个值,失败返回0)/msetnx key1 value1 key2 value2(同上一个,但不覆盖已有的); 

 

(2)获取:get key/getset key value(重设值,并返回旧值)/getrange key index1 index2(返回key对应value的子串:index1到index2)/mget key1 key2 key3(一次获取多个值); 

 

(3)加减法:incr key(如果key的值为int类型,加一;如果key的值为非int类型,返回错误;如果key不存在,则设置key的值为1,即认为原来值为0)/incrby key number(key的值加number,其他同上一个)/decr key/decrby key number(这是减法,规格同incr/incrby); 

 

(4)字符串操作:append key val(将val追加在key对应的值后面)/strlen key(返回key对应的值的长度) 注意点:字符串的左面下标从0开始,右面下标从-1开始。 

 

2、hash:map,即每个hash表中有一到多个键值对 

 

(1)添加:hset myhash key value(添加键值对key->value到hash表myhash中)/hsetnx myhash key value(同hset,但不覆盖)/hmset myhash key1 value1 key2 value2(添加多个键值对到hash表myhash中); 

 

(2)获取:hget myhash key(获取hash表myhash中键为key的值)/hmget myhash key1 key2 key3(获取hash表myhash中多个键的值)/hincrby myhash key number(hash表myhash中key对应的值加number); 

 

(3)其他操作:hexists myhash key(判断myhash中是否存在键为key,0表示无,1表示有)/hlen myhash(返回myhash键数量)/hdel myhash key(删除myhash中键为key的键值对)/hkeys myhash(返回myhash中所有键)/hvals myhash(返回myhash中所有值)/hgetall myhash(返回myhash中所有键和值) 

 

3、list:由value串成的list 

 

(1)添加:lpush mylist value(添加值value到mylist头部)/rpush mylist value(添加值value到mylist尾部)/linsert mylist before value1 value(将value插入到mylist中value1的前面)/lset mylist index value(将mylist中第index位置的值重设为value) 

 

(2)获取:lrange mylist index1 index2(获取list中第index1个到第index2个)/lindex mylist index(返回mylist下标为index的值)/llen mylist(返回mylist的长度) 

 

(3)删除:lrem mylist count value(删除|count|个mylist中值为value的元素,count>0:从头到尾删;count

 

4、set:由value组成的set 

 

(1)添加:sadd myset value 

 

(2)获取:smembers myset(返回myset所有值)/sdiff myset1 myset2(返回两个set的差集)/sdiffstore myset myset1 myset2(将myset1与myset2的差集存在myset中)/sinter myset1 myset2(返回两个set的交集)/sinterstore myset myset1 myset2(将myset1和myset2的交集存在myset中)/sunion myset1 myset2(返回两个set的并集)/sunionstore myset myset1 myset2(将myset1和myset2的并集存在myset中)/scard myset(返回myset的元素个数)/sismember myset value(测试value是否为myset中的元素,1为是,0为否)/srandmember myset(随机返回myset中的一个元素,但不删除) 

 

(3)删除:srem myset value(删除值为value的元素)/spop myset(随机删除并返回myset中的某个元素)/smove myset1 myset2 value(从myset1中移除value并添加到myset2中) 5、sorted set(zset):带排序的set 

 

(1)添加:zadd myzset score value(添加value到myzset,score用于排序,如果已存在value,则更新其score) 

 

(2)获取:zrange myzset index1 index2 withscores(返回myzset中下标范围为index1到index2的元素及其score值,按score从小到大顺序)/zrank myzset value(返回value在myzset中的排名,从0开始计数)/zrevrank myzset value(返回value在myzset中的倒序排名,从0开始计数)/zrevrange myzset index1 index2 withscores(zrange的倒序)/zrangebyscore myzset a b withscores(返回myzset中score在a到b范围的值和score)/zcount myzset a b(返回myzset中score范围在a到b的值的数量)/zcard myzset(返回元素个数)/zscore myzset value(返回myzset中value对应的score值) 

 

(3)删除:zrem myzset value(删除myzset中值为value的元素)/zremrangebyrank myzset index1 index2(删除myzset中score排名在index1到index2之间的元素)/zremrangebyscore myzset a b(删除myzset中score值在a和b之间的元素) 

 

(4)加减score:zincrby myzset number value(将值为value的score加number) 二、redis常用命令: 

 

1、keys pattern:返回给定pattern的所有key,pattern为正则表达式

 

2、exists key:判断是否存在key 

 

3、del key:删除key 

 

4、expire key time:设置一个key的过期时间 

 

5、move key db:将一个key移到数据库db中 

 

6、ttl key:返回key还有多长时间过期(-1表示无过期时间) 

 

7、peisist key:移除key的过期时间 

 

8、randomkey:随机返回某个key 

 

9、rename oldkey newkey:将oldkey重命名为newkey 

 

10、type value:返回value的类型 

 

11、dbsize:返回当前数据库的key数量 

 

12、flushdb:删除当前数据库的所有key

13、flushall:删除所有数据库的所有key 

 

14、info:获取服务器信息和统计 

 

15、config get:获取服务器配置信息 ps:redis的数据库编号为0-15,默认为数据库0。

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn