Redis内存数据库操作命令详解

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介:

一、连接操作相关的命令

   quit关闭连接connection

   auth简单密码认证

二、对value操作的命令

   exists(key)确认一个key是否存在

   del(key)删除一个key

   type(key)返回值的类型

   keys(pattern)返回满足给定pattern的所有key

   randomkey随机返回key空间的一个key

   rename(oldname, newname)将key由oldname重命名为newname若newname存在则删除newname表示的key

   dbsize返回当前数据库中key的数目

   expire设定一个key的活动时间s

   ttl获得一个key的活动时间

   select(index)按索引查询

   move(key, dbindex)将当前数据库中的key转移到有dbindex索引的数据库

   flushdb删除当前选择数据库中的所有key

   flushall删除所有数据库中的所有key

三、对String操作的命令

   set(key, value)给数据库中名称为key的string赋予值value

   get(key)返回数据库中名称为key的string的value

   getset(key, value)给名称为key的string赋予上一次的value

   mget(key1, key2,…, key N)返回库中多个string它们的名称为key1key2…的value

   setnx(key, value)如果不存在名称为key的string则向库中添加string名称为key值为value

   setex(key, time, value)向库中添加string名称为key值为value同时设定过期时间time

   mset(key1, value1, key2, value2,…key N, value N)同时给多个string赋值名称为key i的string赋值value i

   msetnx(key1, value1, key2, value2,…key N, value N)如果所有名称为key i的string都不存在则向库中添加string名称key i赋值为value i

   incr(key)名称为key的string增1操作

   incrby(key, integer)名称为key的string增加integer

   decr(key)名称为key的string减1操作

   decrby(key, integer)名称为key的string减少integer

   append(key, value)名称为key的string的值附加value

   substr(key, start, end)返回名称为key的string的value的子串

四、对List操作的命令

   rpush(key, value)在名称为key的list尾添加一个值为value的元素

   lpush(key, value)在名称为key的list头添加一个值为value的 元素

   llen(key)返回名称为key的list的长度

   lrange(key, start, end)返回名称为key的list中start至end之间的元素下标从0开始下同

   ltrim(key, start, end)截取名称为key的list保留start至end之间的元素

   lindex(key, index)返回名称为key的list中index位置的元素

   lset(key, index, value)给名称为key的list中index位置的元素赋值为value

   lrem(key, count, value)删除count个名称为key的list中值为value的元素。count为0删除所有值为value的元素count>0从头至尾删除count个值为value的元素count<0从尾到头删除|count|个值为value的元素。

   lpop(key)返回并删除名称为key的list中的首元素

   rpop(key)返回并删除名称为key的list中的尾元素

   blpop(key1, key2,… key N, timeout)lpop命令的block版本。即当timeout为0时若遇到名称为key i的list不存在或该list为空则命令结束。如果timeout>0则遇到上述情况时等待timeout秒如果问题没有解决则对key i+1开始的list执行pop操作。

   brpop(key1, key2,… key N, timeout)rpop的block版本。参考上一命令。

   rpoplpush(srckey, dstkey)返回并删除名称为srckey的list的尾元素并将该元素添加到名称为dstkey的list的头部

五、对Set操作的命令

   sadd(key, member)向名称为key的set中添加元素member

   srem(key, member) 删除名称为key的set中的元素member

   spop(key) 随机返回并删除名称为key的set中一个元素

   smove(srckey, dstkey, member) 将member元素从名称为srckey的集合移到名称为dstkey的集合

   scard(key) 返回名称为key的set的基数

   sismember(key, member) 测试member是否是名称为key的set的元素

   sinter(key1, key2,…key N) 求交集

   sinterstore(dstkey, key1, key2,…key N) 求交集并将交集保存到dstkey的集合

   sunion(key1, key2,…key N) 求并集

   sunionstore(dstkey, key1, key2,…key N) 求并集并将并集保存到dstkey的集合

   sdiff(key1, key2,…key N) 求差集

   sdiffstore(dstkey, key1, key2,…key N) 求差集并将差集保存到dstkey的集合

   smembers(key) 返回名称为key的set的所有元素

   srandmember(key) 随机返回名称为key的set的一个元素

六、对zsetsorted set操作的命令

   zadd(key, score, member)向名称为key的zset中添加元素memberscore用于排序。如果该元素已经存在则根据score更新该元素的顺序。

   zrem(key, member) 删除名称为key的zset中的元素member

   zincrby(key, increment, member) 如果在名称为key的zset中已经存在元素member则该元素的score增加increment否则向集合中添加该元素其score的值为increment

   zrank(key, member) 返回名称为key的zset元素已按score从小到大排序中member元素的rank即index从0开始若没有member元素返回“nil”

   zrevrank(key, member) 返回名称为key的zset元素已按score从大到小排序中member元素的rank即index从0开始若没有member元素返回“nil”

   zrange(key, start, end)返回名称为key的zset元素已按score从小到大排序中的index从start到end的所有元素

   zrevrange(key, start, end)返回名称为key的zset元素已按score从大到小排序中的index从start到end的所有元素

   zrangebyscore(key, min, max)返回名称为key的zset中score >= min且score <= max的所有元素

   zcard(key)返回名称为key的zset的基数

   zscore(key, element)返回名称为key的zset中元素element的score

   zremrangebyrank(key, min, max)删除名称为key的zset中rank >= min且rank <= max的所有元素

   zremrangebyscore(key, min, max) 删除名称为key的zset中score >= min且score <= max的所有元素

   zunionstore / zinterstore(dstkeyN, key1,…,keyN, WEIGHTS w1,…wN, AGGREGATE SUM|MIN|MAX) 对N个zset求并集和交集并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score在进行AGGREGATE运算前都要乘以对于 的WEIGHT参数。如果没有提供WEIGHT默认为1。默认的AGGREGATE是SUM即结果集合中元素的score是所有集合对应元素进行 SUM运算的值而MIN和MAX是指结果集合中元素的score是所有集合对应元素中最小值和最大值。

七、对Hash操作的命令

   hset(key, field, value)向名称为key的hash中添加元素field<—>value

   hget(key, field)返回名称为key的hash中field对应的value

   hmget(key, field1, …,field N)返回名称为key的hash中field i对应的value

   hmset(key, field1, value1,…,field N, value N)向名称为key的hash中添加元素field i<—>value i

   hincrby(key, field, integer)将名称为key的hash中field的value增加integer

   hexists(key, field)名称为key的hash中是否存在键为field的域

   hdel(key, field)删除名称为key的hash中键为field的域

   hlen(key)返回名称为key的hash中元素个数

   hkeys(key)返回名称为key的hash中所有键

   hvals(key)返回名称为key的hash中所有键对应的value

   hgetall(key)返回名称为key的hash中所有的键field及其对应的value

八、持久化

   save将数据同步保存到磁盘

   bgsave将数据异步保存到磁盘

   lastsave返回上次成功将数据保存到磁盘的Unix时戳

   shundown将数据同步保存到磁盘然后关闭服务

九、远程服务控制

   info提供服务器的信息和统计

   monitor实时转储收到的请求

   slaveof改变复制策略设置

   config在运行时配置Redis服务器 

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3天前
|
Linux
linux 常用内存检查命令
linux 常用内存检查命令
11 0
|
19天前
|
缓存 NoSQL 数据处理
Redis事务悄然而至:命令的背后故事
Redis事务悄然而至:命令的背后故事
15 0
|
16天前
|
存储 缓存 运维
Linux系统调优详解(四)——内存状态查看命令
Linux系统调优详解(四)——内存状态查看命令
39 7
|
6天前
|
存储 消息中间件 NoSQL
Redis相关命令详解及其原理
Redis相关命令详解及其原理
38 0
|
15天前
|
NoSQL 关系型数据库 MySQL
Windows、Linux、Mac安装数据库(mysql、MongoDB、Redis)#0
不同系统下进行MySQL安装、MongoDB安装、Redis安装
59 5
Windows、Linux、Mac安装数据库(mysql、MongoDB、Redis)#0
|
18天前
|
网络协议 数据库 网络架构
【OSPF Loading、FULL状态与display ospf peer brief命令、OSPF的数据库讲解】
【OSPF Loading、FULL状态与display ospf peer brief命令、OSPF的数据库讲解】
19 0
|
19天前
|
存储 缓存 NoSQL
内存淘金术:Redis 内存满了怎么办?
内存淘金术:Redis 内存满了怎么办?
21 1
|
19天前
|
NoSQL Redis
redis五大数据类型及其常用命令(详细)
redis五大数据类型及其常用命令(详细)
9 0
|
19天前
|
NoSQL Java Redis
springboot整合redis过期key监听实现订单过期操作
springboot整合redis过期key监听实现订单过期操作
16 0
|
22天前
|
NoSQL Java API
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
分布式锁【数据库乐观锁实现的分布式锁、Zookeeper分布式锁原理、Redis实现的分布式锁】(三)-全面详解(学习总结---从入门到深化)
107 0

热门文章

最新文章