详解Redis 键和字符串常用命令
目录
- Redis 相关知识
- Redis中的数据类型
- redis 键(key)
- Redis字符串(String)
- 常用命令
- String的数据结构
Redis 相关知识
Redis的默认端口号为6379
默认16个数据库,类似数组下标从0开始,初始默认使用0号库。
使用命令select 来切换数据库。 如: select 8。
统一密码管理,所有库同样密码。
dbsize查看当前数据库的key的数量。flushdb清空当前库。flushall通杀全部库。
Redis是单线程+多路IO复用技术。
多路复用是指使用一个线程来检查多个文件描述符( Socket )的就绪状态,比如调用select和poll函数,传入多个文件描述符,如果有一个文件描述符就绪,则返回,否则阻塞直到超时。得到就绪状态后进行真正的操作可以在同一个线程里执行,也可以启动线程执行(比如使用线程池)。
串行 VS 多线程+锁 ( memcached) VS 单线程+ 多路IO复用(Redis)
Redis与Memcache三点不同:
- 支持多数据类型
- 支持持久化
- 单线程+多路IO复用
Redis中的数据类型

redis 键(key)
keys *:查看当前库所有key (匹配 : keys *1)

exists key:判断某个key是否存在。type key:查看你的key是什么类型。del key:删除指定的key数据,
unlink key:根据value选择非阻塞删除。仅将keys从keyspace元数据中删除,真正的删除会在后续异步操作。。expire key 10:10 秒钟,为给定的key设置过期时间,ttl key:查看还有多少秒过期, -1表示永不过期, -2表示已过期。
select命令切换数据库,dbsize查看当前数据库的key的数量。flushdb清空当前库。flushall通杀全部库
Redis字符串(String)
String是Redis 最基本的类型,一个key对应一个value。
String类型是二进制安全的。 意味着Redis的string可以包含任何数据。比如jpg图片
或者序列化的对象。
String类型是Redis最基本的数据类型, 一个Redis中字符串value最多可以是512M。
常用命令
set、get等
set :添加键值对。
当设置过值的key再被设置一个新的值时,新的值会覆盖旧的。

*NX:当数据库中key不存在时,可以将key-value添加数据库。
*XX:当数据库中key存在时,可以将key-value添加数据库,与NX参数互斥。
*EX: key的超时秒数。
*PX: key 的超时毫秒数,与EX互斥。
get 查询对应键值.append 将给定的< value >追加到原值的末尾,strlen 获得值的长度。setnx 只有在key不存在时设置 key的值.
增减建的值
incr
将key中储存的数字值增1。
只能对数字值操作,如果为空,新增值为10
decr
将key中储存的数字值减1。
只能对数字值操作。如果为空,新增值为-1。
inrjy/ decrby <步长> 将key中储存的数字值增减。自定义步长。
注意:
incr和decr是原子操作
而java中的i++则不是原子操作
mset、mget和msetnx
mset
....
同时设置一个或多个key-value对。

mget
同时获取一个或多个value。

msetnx
它是原子性的
同时设置一个或多个 key-value对,当且仅当所有给定key都不存在时,才成功。

有一个是之前存在的则不成功

getrange、setrange
getrange
<起始位置><结束位置>
获得值的范围,类似java中的substring ,前包,后包
setrange
<起始位置>
用覆写所储存的字符串值,从<起始位置:开始(索引从0开始)。

设置过期时间
setex
<过期时间>
设置键值的同时,设置过期时间,单位秒。

替换旧值
getset
以新换旧,设置了新值同时获得旧值。

String的数据结构
String的数据结构为简单动态字符串(Simple Dynamic String,縮写SDS)。是可以修改的字符串,内部结构实现上类似于Java的ArrayList ,采用预分配冗余空间的方式来减少内存的频繁分配。

如图中所示,内部为当前字符串实际分配的空间capacity一般要高于实际字符串长度len。当字符串长度小于1M时,扩容都是加倍现有的空间,如果超过1M,扩容时一次只会多扩1M的空间。需要注意的是字符串最大长度为512M。
栏 目:其它数据库
下一篇:Redis+Lua脚本实现计数器接口防刷功能(升级版)
本文标题:详解Redis 键和字符串常用命令
本文地址:https://zz.feitang.co/shujuku/28343.html
您可能感兴趣的文章
- 12-22使用mysql记录从url返回的http GET请求数据操作
- 12-22详解sql中exists和in的语法与区别
- 12-22hive从mysql导入数据量变多的解决方案
- 12-22如何为PostgreSQL的表自动添加分区
- 12-22postgresql 实现得到时间对应周的周一案例
- 12-22sqoop export导出 map100% reduce0% 卡住的多种原因及解决
- 12-22mysql查询条件not in 和 in的区别及原因说明
- 12-22解决mysql使用not in 包含null值的问题
- 12-22解决从集合运算到mysql的not like找不出NULL的问题
- 12-22postgresql 实现多表关联删除


阅读排行
推荐教程
- 12-11mysql代码执行结构实例分析【顺序、分支、循环结构】
- 12-08添加mysql的用户名和密码是什么语句?
- 12-20PhpMyAdmin出现错误数据无法导出怎么办?
- 12-19Redis中实现查找某个值的范围
- 12-15浅析mysql迁移到clickhouse的5种方法
- 12-15CentOS7 64位下MySQL5.7安装与配置教程
- 12-14Mysql大型SQL文件快速恢复方案分享
- 12-14mysql 5.7.27 安装配置方法图文教程
- 12-13MySQL给新建用户并赋予权限最简单的方法
- 12-13关于MySQL索引的深入解析





