Redis_客户端命令和数据操作(3)
更多命令请查找:http://c.biancheng.net/redis_command/
切换数据库
redis数据库没有名称,默认有16个,通过0-15来标识,连接redis默认选择第一个数据库,可以通过命令 select 库号 进行数据库的切换

键命令
keys
查找键,参数⽀持正则表达式。语法如下:
keys pattern

exists
判断键是否存在,如果存在返回1,不存在返回0。语法如下:
exists key

type
查看key对应的value的数据类型,如果key不存在则返回none。语法如下:
type key

del
删除指定key的数据,若key存在返1,若key不存在则返0。语法如下:
del key

expire&ttl
设置数据时,如果忘了添加过期时间,我们可以使用expire为数据增加过期时间。语法如下:
expire key seconds
设置好过期时间后我们可以使用tll查看过期剩余时间,如果数据是永不过期则返 -1,如果已过期则返 -2,如果是待过期则返过期剩余时间。语法如下:
ttl key

数据结构
- redis是key-value的数据结构,每条数据都是⼀个键值对
- 键的类型是字符串
注意:键不能重复
值的类型分为五种:
- 字符串string
- 哈希hash
- 列表list
- 集合set
- 有序集合zset
string类型
字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。
set&get
使用 set 方法添加键值,如果添加的键已经存在则修改。语法如下:
set key value
使用 get 方法获取键的值,如果键不存在则返回nil。语法如下:
get key

mset&mget
set和get一次只能设置一个或获取一个值,当我们想一次设置或获取多个是需要使用mset和mget。语法如下
# mset设置多个值
mset key1 value1 key2 value2 ... # mget获取多个值
mget key1 key2 ...

append
向已存在的字符串中追加值,如果键不存在则创建。语法如下:
append key value

setex
上面设置键值的方法过期时间默认是永久,如果想直接设置自动过期的键值需要使用setex方法。语法如下:
setex key seconds value

hash类型
- hash类型⽤于存储对象,对象的结构为属性、值
- 值的类型为string
hset&hmset
hset用于设置对象的属性和值,一次可以设置单个属性、值,也可以设置多个属性、值,hash类型的数据对象是可以追加和修改的,如果field不存在则追加,如果存在则修改。语法如下:
# 设置key对象
hset key field1 value1 [field2 value2 ...] # 修改已有属性的值
hset key field1 newValue # 新增属性和值
hset key newField value
说明,在4.0版本之前,hset只能设置单个属性和值,在之后版本hset和hmset功能一致。
hkeys&hget&hmget&hvals
不同类型获取数据的方式不一样,如果没有用对应数据类型的方法获取数据,则会报错 (error) WRONGTYPE Operation against a key holding the wrong kind of value,对于hash类型的数据我们使用4中方法来分别获取对象的属性和值。语法如下:
# 获取指定hash对象所有的属性
hkeys key # 获取⼀个属性的值
hget key field # 获取多个属性的值
hmget key field1 field2 ... # 获取所有属性的值
hvals key

list类型
- 列表的元素类型为string
- 按照插⼊顺序排序
- 可插入重复元素
lpush&rpush
lpush、rpush方法的作用是从左侧、从右侧插入元素。语法如下:
# 从左侧插入数据。当插入第一个值后,第二个值插入到第一个值左侧,第三个值插入到第二个值左侧...
lpush key element [element ...] # 从右侧插入数据。与左侧插入相反
rpush key element [element ...]
linsert key [ before | after ]
在指定元素的前或后插⼊新元素,如果输入的现有元素不存在则会插入失败返-1。语法如下:
linsert key BEFORE|AFTER 现有元素 插入元素

lrange
获取列表指定索引范围内的元素。语法如下:
lrange key start stop
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
- 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素
- 超出索引值不会报错

lset
修改列表指定索引位置的元素。语法如下:
lset key index value
- 索引从左侧开始,第⼀个元素为0
索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素
- 超出索引值会报错

lrem
删除列表指定元素。语法如下:
lrem key count value
- 从列表中删除count次value元素
- count > 0: 从左侧移除
- count < 0: 从右侧移除
- count = 0: 移除所有
- 删除不存在的值不会报错

set类型
- ⽆序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 无修改操作
sadd
用于向集合中添加元素,若元素已存在则不会添加返回0。语法如下:
sadd key member [member ...]

smembers
用于获取集合中的元素。语法如下:
smembers key

srem
用于删除集合指定元素。语法如下:
srem key member [member ...]

zset类型
- sorted set,有序集合
- 元素为string类型
- 元素具有唯⼀性,不重复
- 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序
- 无修改操作
zadd
用于向有序集合中添加元素。语法如下:
zadd key [NX|XX] [CH] [INCR] score member [score member ...]

zrange
用于获取指定索引范围内的元素。语法如下:
zrange key start stop [WITHSCORES]
- start、stop为元素的下标索引
- 索引从左侧开始,第⼀个元素为0
索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素

zrangebyscore
返回score值在min和max之间的元素。语法如下:
zrangebyscore key min max [WITHSCORES] [LIMIT offset count]

zscore
返回指定元素的score值。语法如下:
zscore key member

zrem
删除指定元素。语法如下:
zrem key member [member ...]

zremrangebyscore
删除权重在指定范围的元素。语法如下:
zremrangebyscore key min max

查看中文value
redis的value存储中文后,获取值后显示16进制的字符串,比如:张三 ===> \xe5\xbc\xa0\xe4\xb8\x89

如果想要查看中文,使用 命令: redis-cli --raw 进入redis获取值即可。

更多命令介绍,请查看https://www.cnblogs.com/progor/p/8540246.html
Redis_客户端命令和数据操作(3)的更多相关文章
- MySQL命令行数据操作使用心得(总结版)
Char 0~255 Varchar 0~65535 text 0~65535(只能保存字符) Longtext 0~4294967295(只能保存字符) CMD登陆mysql mysql -u ro ...
- Django 链接MySQL及数据操作
Django 链接MySQL Django创建的项目自带的数据库是SQLite3,我们想要链接MySQL的话,需要更改settings.py中的配置 1.在MySQL中创建好数据库,Django项目不 ...
- ZooKeeper学习笔记(四)——shell客户端命令操作
ZooKeeper客户端命令行操作 启动服务端 [simon@hadoop102 zookeeper-3.4.10]$ bin/zkServer.sh start 查看状态信息 Using confi ...
- MongoDB学习笔记~客户端命令行的使用
回到目录 当我们从MongoDB网站下载安装包之后,它会伴随有一系列的工具,服务器程序mongod是我们耳熟能详的了,客户端mongo和性能检测mongostat我们可能就没有用过了,今天主要是介绍一 ...
- SQL不同服务器数据库之间的数据操作整理(完整版)
---------------------------------------------------------------------------------- -- Author : htl25 ...
- [SQL]SQL语言入门级教材_SQL数据操作基础(二)
SQL数据操作基础(初级) netnova 于 -- :: 加贴在 数据库探讨: 为了建立交互站点,你需要使用数据库来存储来自访问者的信息.例如,你要建立一个职业介绍服务的站点,你就需要存储诸如个人简 ...
- SQLServer服务器数据库之间的数据操作(完整版)
分类: 数据库开发技术 ---------------------------------------------------------------------------------- -- Au ...
- 转载-SQL不同服务器数据库之间的数据操作整理(完整版) .
---------------------------------------------------------------------------------- -- Author : htl25 ...
- SQL语言-----数据操作
数据操作 增加数据,insert into 标准格式 insert into 表名 (字段的列表)value(数据列表): 使用set insert into 表名 set 字段1=值,2.....: ...
随机推荐
- sqlserver 各种判断是否存在(表、视图、函数、存储过程等)
1.判断表是否存在 select * from sysobjects where id = object_id(表名) and OBJECTPROPERTY(id, N'IsUserTable') = ...
- 如何使用cURL获得请求/响应具体耗时?
如何使用cURL一次测量请求和响应时间? cURL支持格式化输出请求的详细信息(请参阅cURL手册页的-w.–write out<format>获取更多信息). 如题,我们将只关注如何知晓 ...
- 阿里面试题: (a,b,c)组合索引, 查询语句select...from...where a=.. and c=..走索引吗?
面试官:(a,b,c)组合索引,查询语句select...from...where a=.. and c=..走索引吗应聘者: 最佳左前缀法,如果索引了多列,要遵守最左前缀法则,否则索引失效 按最左前 ...
- 使用.NET 6开发TodoList应用(2)——项目结构搭建
为了不影响阅读的体验,我把系列导航放到文章最后了,有需要的小伙伴可以直接通过导航跳转到对应的文章 : P TodoList需求简介 首先明确一下我们即将开发的这个TodoList应用都需要完成什么功能 ...
- 记一次 .NET 某市附属医院 Web程序 偶发性CPU爆高分析
一:背景 1. 讲故事 这个月初,一位朋友加微信求助他的程序出现了 CPU 偶发性爆高,希望能有偿解决一下. 从描述看,这个问题应该困扰了很久,还是医院的朋友给力,开门就是 100块 红包 ,那既然是 ...
- .NET 云原生架构师训练营(系统架构)--学习笔记
目录 对外展现的功能 内部功能 功能交互与价值通路 系统架构 目标 认识系统的价值通路 认识功能架构,通过把功能结构与形式结构结合来描述系统架构 受益原则 好的架构必须使人受益,要想把架构做好,就要专 ...
- AT266 迷子のCDケース 题解
Content 有 \(n+1\) 个碟,编号为 \(0\sim n\),一开始 \(0\) 号碟在播放机上,其他的碟依次放进了 \(n\) 个盒子里面.现在有 \(m\) 次操作,每次操作找到当前在 ...
- mysql 在删除数据出现Cannot delete or update a parent row: a foreign key constraint fails 这个该如何解决
mysql 在删除数据出现Cannot delete or update a parent row: a foreign key constraint fails 这个该如何解决 可以这样解决: S ...
- mobx在react的使用
创建项目第六步 mobx 1.安装 yarn add mobx yarn add mobx-react 2.新建/src/store/store.js import {observable, co ...
- centos使用docker安装clickhouse
拉取镜像 docker pull yandex/clickhouse-server:20.3.12.112 启动 docker run -d --name=clickhouse-server -p 8 ...