Home >Database >Mysql Tutorial >redis学习笔记
一、几种数据结构: 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。