文章目录
命令操作
Redis 数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
Redis存储的是: key,value格式的数据,其中key都是字符串,value有5种不同的数据结构。
value的数据结构
- 字符串类型string
- 哈希类型hash : map格式
- 列表类型list : linkedlist格式。 支持重复元素
- 集合类型set :不允许重复元素
- 有序集合类型sortedset :不允许重复元素,且元素有顺序
一、字符串类型string
- 存储: set key value
- 获取: get key
- 删除: del key
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。
string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。
实例
redis 127.0.0.1:6379> SET lyh "菜鸟"
OK
redis 127.0.0.1:6379> GET lyh
"菜鸟"
在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 lyh,对应的值为 菜鸟。
注意: 一个键最大能存储 512MB。
二、哈希类型hash
哈希类型hash
- 存储:
hset key field value - 获取:
hget key field:获取指定的field对应的值
hgetall key :获取所有的field和value - 删除:
hdel key field
Redis hash 是一个键值(key=>value)对集合。
Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
redis 127.0.0.1:6379> HMSET lyh field1 "Hello" field2 "World"
"OK"s
redis 127.0.0.1:6379> HGET lyh field1
"Hello"
redis 127.0.0.1:6379> HGET lyh field2
"World"
使用了 Redis HMSET, HGET 命令,HMSET 设置了两个 field=>value 对, HGET 获取对应 field 对应的 value。
每个 hash 可以存储 2^32 -1 键值对(40多亿)。
三、列表类型list
列表类型list:
可以添加一个元素到列表的头部(左边)或者尾部(右边)
- 添加:
- lpush key value:将元素加入列表左表
- rpush key value:将元素加入列表右边
- 获取:
- lrange key start end : 范围获取
- 删除:
- lpop key:删除列表最左边的元素, 并将元素返回;
- rpop key:删除列表最右边的元素, 并将元素返回;
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
redis 127.0.0.1:6379> DEL lyh
redis 127.0.0.1:6379> lpush lyh redis
(integer) 1
redis 127.0.0.1:6379> lpush lyh mongodb
(integer) 2
redis 127.0.0.1:6379> lpush lyh rabbitmq
(integer) 3
redis 127.0.0.1:6379> lrange lyh 0 10
1) "rabbitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>
列表最多可存储 2^32 - 1 元素 (4294967295, 每个列表可存储40多亿)。
四、集合类型set
集合类型set:
不允许重复元素
- 存储:
sadd key value - 获取:
smembers key:获取set集合中所有元素 - 删除:
srem key value:删除set集合中的某个元素
Redis 的 Set 是 string 类型的无序集合。
集合是通过哈希表实现的。
sadd 命令
添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。
sadd key member
redis 127.0.0.1:6379> DEL lyh
redis 127.0.0.1:6379> sadd lyh redis
(integer) 1
redis 127.0.0.1:6379> sadd lyh mongodb
(integer) 1
redis 127.0.0.1:6379> sadd lyh rabbitmq
(integer) 1
redis 127.0.0.1:6379> sadd lyh rabbitmq
(integer) 0
redis 127.0.0.1:6379> smembers lyh
1) "redis"
2) "rabbitmq"
3) "mongodb"
注意: 以上实例中 rabbitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为 2^32 - 1(4294967295, 每个集合可存储40多亿个成员)。
五、有序集合类型zset(sorted set:有序集合)
有序集合类型sortedset :不允许重复元素,且元素有顺序
- 存储:
zadd key score value - 获取:
zrange key start end - 删除:
zrem key value
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
redis 127.0.0.1:6379> DEL lyh
redis 127.0.0.1:6379> zadd lyh 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd lyh 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd lyh 0 rabbitmq
(integer) 1
redis 127.0.0.1:6379> zadd lyh 0 rabbitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE lyh 0 1000
1) "mongodb"
2) "rabbitmq"
3) "redis"
通用命令
keys *
:查询所有的键type key
:获取键对应的value的类型del key
:删除指定的key value
Redis 命令
Redis 命令用于在 redis 服务上执行操作。
要在 redis 服务上执行命令需要一个 redis 客户端。Redis 客户端在我们之前下载的的 redis 的安装包中。
语法
Redis 客户端的基本语法为:
$ redis-cli
启动 redis 服务器,打开终端并输入命令 redis-cli,该命令会连接本地的 redis 服务。
$ redis-cli
redis 127.0.0.1:6379>
redis 127.0.0.1:6379> PING
PONG
在以上实例中我们连接到本地的 redis 服务并执行 PING 命令,该命令用于检测 redis 服务是否启动。
在远程服务上执行命令
如果需要在远程 redis 服务上执行命令,同样我们使用的也是 redis-cli 命令。
语法
$ redis-cli -h host -p port -a password
以下实例演示了如何连接到主机为 127.0.0.1,端口为 6379 ,密码为 mypass 的 redis 服务上。
$redis-cli -h 127.0.0.1 -p 6379 -a "mypass"
redis 127.0.0.1:6379>
redis 127.0.0.1:6379> PING
PONG
有时候会有中文乱码。
要在 redis-cli 后面加上 --raw
redis-cli --raw
就可以避免中文乱码了。