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

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 一、连接操作相关的命令 Ÿ   quit:关闭连接(connection) Ÿ   auth:简单密码认证 二、对value操作的命令 Ÿ   exists(key):确认一个key是否存在 Ÿ   del(key):删除一个key Ÿ   type(key):返回值的类型 Ÿ   k...

一、连接操作相关的命令

   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服务器


作者张子良
出处http://www.cnblogs.com/hadoopdev
本文版权归作者所有欢迎转载但未经作者同意必须保留此段声明且在文章页面明显位置给出原文连接否则保留追究法律责任的权利。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
相关文章
|
11月前
|
消息中间件 网络协议 NoSQL
1000W长连接,如何建立和维护?千万用户IM 架构设计
最近有小伙伴在面试 美团,又遇到了 IM 架构问题。小伙伴支支吾吾的说了几句,面试挂了。 所以,尼恩给大家做一下系统化、体系化的梳理,使得大家内力猛增,可以充分展示一下大家雄厚的 “技术肌肉”,**让面试官爱到 “不能自已、口水直流”**,然后实现”offer直提”
|
8月前
|
机器学习/深度学习 运维 监控
利用深度学习进行系统健康监控:智能运维的新纪元
利用深度学习进行系统健康监控:智能运维的新纪元
291 30
|
存储 分布式计算 负载均衡
什么是 HBase?其组件起什么作用?
【8月更文挑战第12天】
1518 4
|
12月前
|
SQL 关系型数据库 分布式数据库
用Ganos低代码实现免切片遥感影像浏览
本文介绍了一种基于PolarDB兼容PostgreSQL 14的高效栅格数据管理和可视化方案。推荐配置包括4核CPU、16GB内存、50GB磁盘等。通过创建扩展并上传影像至OSS,利用SQL语句完成数据导入、镶嵌、匀色及金字塔构建。重点介绍了使用ST_AsTile函数动态生成标准瓦片的方法,支持多种格式和增强方式。前端通过Python实现服务接口,实现实时、高效的数据展示。此方案具有实时性强、存储成本低等优点,适合快速可视化大量栅格数据。
145 0
|
JSON 开发工具 C语言
编程入门(五)【Visual Studio Code安装与C/C++语言运行】
编程入门(五)【Visual Studio Code安装与C/C++语言运行】
930 0
|
JavaScript
win10执行npm出现Error: EBUSY: resource busy or locked 错误解决方法
win10执行npm出现Error: EBUSY: resource busy or locked 错误解决方法
1392 0
win10执行npm出现Error: EBUSY: resource busy or locked 错误解决方法
|
存储 数据可视化 数据库
Grafana数据可视化工具安装与应用
关键词:Grafana、Elasticsearch、Table、Gauge、BarGrauge、Graph、PieChart、Variables。
5642 0
Grafana数据可视化工具安装与应用
|
安全 关系型数据库 MySQL
关于Aborted connection告警日志的分析
有时候,连接MySQL的会话经常会异常退出,错误日志里会看到"Got an error reading communication packets"类型的告警。本篇文章我们一起来讨论下该错误可能的原因以及如何来规避。
1049 0
关于Aborted connection告警日志的分析
|
SQL Oracle 关系型数据库
Oracle SQL Plus使用说明
本文目录 1. 简介 2. SQL Plus的登录和退出 3. SQL Plus查询命令
405 0
Oracle SQL Plus使用说明
|
运维 资源调度 调度
阿里巴巴任务调度SchedulerX兼容XXL-JOB
阿里巴巴任务调度SchedulerX2.0兼容XXL-JOB任务接口,支持@XxlJob新注解和@JobHandler老注解方式,用户不需要修改一行代码,即可以将XXL-JOB任务在SchedulerX2.0平台上托管。
4432 1
阿里巴巴任务调度SchedulerX兼容XXL-JOB