您的位置:首页 > 数据库 > Redis

Redis学习笔记之redis基础

2017-06-03 16:15 399 查看
资料来源:http://www.atguigu.com/download.shtml一,Redis是什么?Redis:REmote DIctionary Server(远程字典服务器),是一个用C语言编写的,遵守BSD协议,高性能的(key/value)分布式内存数据库(开源),基于内存运行并支持持久化,是当前最热门的NoSql数据库之一,也被人们称为数据结构服务器。二,redis的特点支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。Redis支持数据的备份,即master-slave模式的数据备份三,永远的hello world安装redis就不多说了,解压安装包之后再在解压目录make,makeinstall。查看默认安装目录(注,多余的rdb文件和log文件是我自己新建的):redis-benchmark: 性能测试工具redis-check-aof:修复有问题的AOF文件redis-check-dump:修复有问题的dump.rdb文件redis-cli:客户端,操作入口redis-sentinel:redis集群使用redis-server:Redis服务器启动命令为了不改变默认配置,将redis.conf(redis的解压目录中)拷贝出来,保存在其他目录,如我保存在/root/myredis目录下。修改redis.conf文件将里面的daemonize no 改成 yes,让服务在后台启动。启动redis:
redis-server /root/myredis/redis.conf
#设置Redis服务端启动配置文件
redis-cli -p 6379
#启动Redis客户端进程
测试连通性
127.0.0.1:6379> pingPONG127.0.0.1:6379> 
helloworld示例:
127.0.0.1:6379> set hello HelloWorldOK127.0.0.1:6379> get hello"HelloWorld"
四,杂项知识redis默认16个数据库,类似数组下标从零开始,初始默认使用零号库Select 命令切换数据库Dbsize 查看当前数据库的key的数量Flushdb:清空当前库Flushall:通杀全部库统一密码管理:每一个数据库都是同样密码redis索引都是从零开始,启动端口默认是6379五,redis的key和五大数据类型key:keys * 查看数据库中所有的键
127.0.0.1:6379> keys *1) "hello"
exists key hello 判断某个key是否存在
127.0.0.1:6379> exists key hello(integer) 1
expire key 秒钟:为给定的key设置过期时间ttl key 查看还有多少秒过期,-1表示永不过期,-2表示已过期数据类型之String类型:string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。一个redis中字符串value最多可以是512Mset/get/del/append/strlen,添加、查询、修改、删除字符串以及得到字符串长度
127.0.0.1:6379> set key1 val1OK127.0.0.1:6379> get key1"val1"127.0.0.1:6379> strlen key1(integer) 4127.0.0.1:6379> append key1 haha(integer) 8127.0.0.1:6379> get key1"val1haha"127.0.0.1:6379> del key1(integer) 1127.0.0.1:6379> keys *1) "hello"
incr/decr/incrby/decrby,对字符串进行加减,一定要是数字才能进行加减
127.0.0.1:6379> incr key2(integer) 2127.0.0.1:6379> get key2"2"127.0.0.1:6379> decr key2(integer) 1127.0.0.1:6379> get key2"1"127.0.0.1:6379> incrby key2 3(integer) 4127.0.0.1:6379> get key2"4"127.0.0.1:6379> decrby key2 3(integer) 1127.0.0.1:6379> get key2"1"
getrange: 获取指定范围内的值,从零到负一表示全部setrange: 设置指定区域内的值
 127.0.0.1:6379> set key3 abcd123OK127.0.0.1:6379> GETRANGE key3 0 -1"abcd123"127.0.0.1:6379> SETRANGE key3 4 efgh(integer) 8127.0.0.1:6379> get key3"abcdefgh"
setex(set with expire)键秒值/setnx(set if not exist)setex:设置带过期时间的key,动态设置。格式:setex 键 秒值 真实值setnx:只有在 key 不存在时设置 key 的值。
127.0.0.1:6379> setex k4 10 v4OK127.0.0.1:6379> ttl k4(integer) 5
mset/mget/msetnxmset:同时设置一个或多个 key-value 对。mget:获取所有(一个或多个)给定 key 的值。msetnx:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。
 127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3OK127.0.0.1:6379> mget k1 k2 k31) "v1"2) "v2"3) "v3"127.0.0.1:6379> msetnx k4 v4 k5 v5(integer) 0127.0.0.1:6379> mget k4 k51) (nil)2) "v5"
数据类型之list: List(列表)底层实际是个链表lpush/rpush/lrange,生成链表,lpush最先保存的序号在最前面
127.0.0.1:6379> LPUSH list01 1 2 3 4 5(integer) 5127.0.0.1:6379> LRANGE list01 0 -11) "5"2) "4"3) "3"4) "2"5) "1"127.0.0.1:6379> RPUSH list02 1 2 3 4 5(integer) 5127.0.0.1:6379> LRANGE list02 0 -11) "1"2) "2"3) "3"4) "4"5) "5"
lpop/rpop,得到最左边的值和最右边的值
127.0.0.1:6379> lpop list01"5"127.0.0.1:6379> rpop list01"1"127.0.0.1:6379> lrange list01 0 -11) "4"2) "3"3) "2"
lindex,按照索引下标获得元素(从上到下),llen获取list的大小
127.0.0.1:6379> LINDEX list01 2"2"
127.0.0.1:6379> LLEN list01(integer) 3
ltrim:截取指定索引区间的元素,格式是ltrim list的key 起始索引 结束索引,截取当前范围的值再赋值给keyrpoplpush 源列表 目的列表,移除列表的最后一个元素,并将该元素添加到另一个列表并返回数据类型Set,无序集合
127.0.0.1:6379> sadd set01 1 1 2 2 3 3(integer) 3127.0.0.1:6379> SMEMBERS set011) "1"2) "2"3) "3"
#判断是否是set01集合成员127.0.0.1:6379> SISMEMBER set01 1(integer) 1
scard,获取集合里面的元素个数srem key value 删除集合中元素
127.0.0.1:6379> SCARD set01(integer) 3127.0.0.1:6379> SREM set01 3(integer) 1127.0.0.1:6379> SMEMBERS set011) "1"2) "2"
srandmember key 某个整数(随机出几个数)spop key 随机出栈smove key1 key2 在key1里某个值 , 作用是将key1里的某个值赋给key2
 127.0.0.1:6379> sadd set02 1 2 3 6 7 8(integer) 6127.0.0.1:6379> smembers set021) "1"2) "2"3) "3"4) "6"5) "7"6) "8"127.0.0.1:6379> sadd set01 1 2 3 4 5 6 7(integer) 5127.0.0.1:6379> smove set01 set02 5(integer) 1127.0.0.1:6379> smembers set021) "1"2) "2"3) "3"4) "5"5) "6"6) "7"7) "8"
交集(sinter key1 key2)/并集(sunion key1 key2)/差集(sdiff key1 key2)数据类型之Hash:Hash(哈希,类似Java里的Map
127.0.0.1:6379> hset user id 11(integer) 1127.0.0.1:6379> hget user id"11"127.0.0.1:6379> hmset user id 11 name zhangsan sex maleOK127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"5) "sex"6) "male"127.0.0.1:6379> hmget user id name1) "11"2) "zhangsan"127.0.0.1:6379> hdel user sex(integer) 1127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"
hlen:获取hash列表的键值对数目
127.0.0.1:6379> hmset user id 11 name zhangsan sex male age 22OK127.0.0.1:6379> hgetall user1) "id"2) "11"3) "name"4) "zhangsan"5) "sex"6) "male"7) "age"8) "22"127.0.0.1:6379> hlen user(integer) 4
hexists key 在key里面的某个值的keyhkeys/hvals key,获取某个hash列表的key值和value值hincrby key key1 n,hash列表某个key的value值加n
127.0.0.1:6379> hexists user id(integer) 1127.0.0.1:6379> hkeys user1) "id"2) "name"3) "sex"4) "age"127.0.0.1:6379> hvals user1) "11"2) "zhangsan"3) "male"4) "22"127.0.0.1:6379> hincrby user age 2(integer) 24127.0.0.1:6379> hvals user1) "11"2) "zhangsan"3) "male"4) "24"
数据类型之zset:sorted set,有序集合,在set基础上,加一个score值。之前set是k1 v1 v2 v3,现在zset是k1 score1 v1 score2 v2。
127.0.0.1:6379> zadd zset01 60 v1 70 v2 80 v3 90 v4 100 v5(integer) 5127.0.0.1:6379> zrange zset01 0 -11) "v1"2) "v2"3) "v3"4) "v4"5) "v5"127.0.0.1:6379> zrange zset01 0 -1 withscores1) "v1"2) "60"3) "v2"4) "70"5) "v3"6) "80"7) "v4"8) "90"9) "v5"10) "100"
zrangebyscore key 开始score 结束score
127.0.0.1:6379>  zrangebyscore zset01 60 901) "v1"2) "v2"3) "v3"4) "v4"
limit用法:
127.0.0.1:6379>  zrangebyscore zset01 60 90 limit 2 21) "v3"2) "v4"
zrem key 某score下对应的value值,作用是删除元素zcount key score区间/zrank key values值,作用是获得下标值。zscore key 对应值,获得分数
127.0.0.1:6379> zrank zset01 v4(integer) 3127.0.0.1:6379> zcount zset01 60 90(integer) 4127.0.0.1:6379> zscore zset01 v4"90"
逆序获得zset集合值
127.0.0.1:6379> zrevrange zset01 0 -11) "v4"2) "v3"3) "v2"4) "v1"
根据分数逆序获取value值
127.0.0.1:6379> zrevrangebyscore zset01  90 601) "v4"2) "v3"3) "v2"4) "v1"
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: