redis-server.exe redis.windows.conf
// redis-cli -h host -p port -a password, 加锁则需要输入密码连接(需要吧redis-cli.exe加入环境变量) redis-cli.exe -h 127.0.0.1-p 6379 -a 123456 CONFIG set requirepass "runoob" // 设置密码,远程连接时输入密码才可以执行命令
1、String(字符串)
string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。string类型是Redis最基本的数据类型,一个键最大能存储512MB。
应用场景:
redis 127.0.0.1:6379> SET name "runoob" OK redis 127.0.0.1:6379> GET name "runoob"
在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 name,对应的值为 runoob。
注意:一个键最大能存储512MB。
应用场景:零散的数据存储....
2、Hash(哈希)
Redis hash 是一个键名对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
127.0.0.1:6379> HMSET user:1 username runoob password runoob points 200
OK
127.0.0.1:6379> HGETALL user:11)"username"2)"runoob"3)"password"4)"runoob"5)"points"6)"200"
以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis HMSET, HGETALL 命令,user:1 为键值。每个 hash 可以存储 232 -1 键值对(40多亿)。
应用场景:一个对象拥有很多属性。比如:一个用户对象,附属有名字,年龄,性别,职业等信息。
3、List(列表,队列)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
redis 127.0.0.1:6379> lpush runoob redis (integer)1 redis 127.0.0.1:6379> lpush runoob mongodb (integer)2 redis 127.0.0.1:6379> lpush runoob rabitmq (integer)3 redis 127.0.0.1:6379> lrange runoob 0101)"rabitmq"2)"mongodb"3)"redis" redis 127.0.0.1:6379>
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
应用场景:显示最新加入的数据信息....
4、Set(集合)
Redis的Set是string类型的无序集合。且不允许重复的成员。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
sadd 命令
添加一个string元素到,key对应的set集合中,成功返回1,如果元素已经在集合中返回0,key对应的set不存在返回错误。
sadd key member
redis 127.0.0.1:6379> sadd runoob redis (integer)1 redis 127.0.0.1:6379> sadd runoob mongodb (integer)1 redis 127.0.0.1:6379> sadd runoob rabitmq (integer)1 redis 127.0.0.1:6379> sadd runoob rabitmq (integer)0 redis 127.0.0.1:6379> smembers runoob 1)"rabitmq"2)"mongodb"3)"redis"
注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
应用场景:数据统计....
5、zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
redis 127.0.0.1:6379> zadd runoob 0 redis (integer)1 redis 127.0.0.1:6379> zadd runoob 0 mongodb (integer)1 redis 127.0.0.1:6379> zadd runoob 0 rabitmq (integer)1 redis 127.0.0.1:6379> zadd runoob 0 rabitmq (integer)0 redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 010001)"redis"2)"mongodb"3)"rabitmq"