Redis(三)--Redis的基本命令

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 这一篇文章我们主要是来整理下Redis的一些常用命令。

前言

这一篇文章我们主要是来整理下Redis的一些常用命令。

基本命令

1.启动Redis

./src/redis-server redis.conf

2.连接Redis数据库

./src/redis-cli -h 127.0.0.1 -p 6379

3.切换数据库
redis中有16个数据库,分别是0~15库,默认操作的是0库,如果要切换数据库的话可以通过select命令切换。

select [dbId]
#切换到1库
select 1

4.查看当前数据库的key的数量

dbsize

5.清空当前库

flushdb

6.判断某个key是否存在

exists key

7.查看你的key是什么类型

type key

8.为给定的key设置过期时间

expire key seconds
#指定名为username的键的过期时间是10秒
例如:expire username 10

9.查看还有多少秒过期,-1表示永不过期,-2表示已过期

ttl key

字符串相关的操作命令

String 数据类型主要用在做缓存,计数器,分布式锁,分布式ID等等

1.设置一个字符串类型的值

set key value
 例如: set testkey testvalue

2.获取字符串的值

get key
 例如:get testkey

3.. 删除指定的key的值

del key
例如:del testkey

4.不存在就插入(not exists),
存在的话就不会插入,这是Redis做分布式锁的基础命令

setnx key value
  例如:127.0.0.1:6379> setnx username zhangsan
(integer) 1

5.递增

incr key
incrby key increment 
例如:127.0.0.1:6379> incr age

6.递减

decr key  
decrby key decrement
例如:
127.0.0.1:6379> decr age
(integer) 1
127.0.0.1:6379> decrby age 3
(integer) -2

hash(哈希)

Redis hash 是一个键值对集合,Redis hash是一个String类型的field和value的映射表,hash特别适合存储对象,例如SpringSession中的session信息,存储用户信息,用户主页访问量等等。

1.设置单个field值

hset key field value
例如:HSET company:1 companyname  alibaba

2.设置多个field值

hmset key field1 value1 [field2 value2 field3 value3 ......fieldn valuen]
例如:HMSET user:1 username zhangsna age 12

3.返回key中的field域的值

HGET key field
例如:
127.0.0.1:6379> HGET company:1 companyname
"alibaba"

4.返回key中的field1,field2,fieldN域的值

hmget key field1 field2 fieldN
例如:
127.0.0.1:6379> HMGET user:1 username age
1) "zhangsna"
2) "12"

5.返回key中,所有的域与其值

hgetall key
例如:
127.0.0.1:6379> HGETALL user:1
1) "username"
2) "zhangsna"
3) "age"
4) "12"

6.删除键

hdel key field[field ....]
例如:127.0.0.1:6379> hdel company:1 companyname
(integer) 1

list列表

字符串列表,按照插入顺序,添加一个元素到列表的头部(左边)或者尾部(右边),可以用于微博关注人,微博时间轴列表

充当队列的原理

左侧入队列

stringRedisTemplate.opsForList().leftPush(key, value)

右侧出队列

stringRedisTemplate.opsForList().rightPop(key)

将一个或多个值插入到列表头部

lpush key value1 [value2] 
例如:127.0.0.1:6379> lpush order 111 222
(integer) 2

获取列表指定范围内的数据

lrange key start stop 
例如:127.0.0.1:6379> lrange order 0 1
1) "222"
2) "111"

移除列表元素

lrem key count value 
例如:127.0.0.1:6379> lrem order 1 111
(integer) 1

通过索引设置元素列表的值

lset key index value 
例如:127.0.0.1:6379> lset order 0 123
OK

移除并获取列表最后一个元素

rpop key
例如:127.0.0.1:6379> rpop order
"123"

在列表尾部添加一个或者多个元素

rpush key value1 [value2] 
例如:127.0.0.1:6379> rpush student zhangsan lisi wanger
(integer) 3

set 集合

set 集合是String类型的无序集合,集合是通过哈希表实现的。所以添加,删除,查找的复杂度都是O(1)。set 集合一般用于,赞,踩,标签等场景.

18. 添加一个元素到集合中(集合中的元素无序并且唯一)

sadd key member [member ...]
例如: 127.0.0.1:6379> sadd myset test
(integer) 1

查看集合中所有的元素

smembers key
例如:127.0.0.1:6379> smembers myset
1) "test"

删除结点中指定的元素

srem key member [member ...]
例如:127.0.0.1:6379> srem myset test
(integer) 1

scard: 返回集合元素的数量

scard key
例如:127.0.0.1:6379> scard key
(integer) 0

smove: 将一个集合的元素转移到另一个集合中\

smove source destionation member
例如:
127.0.0.1:6379> smembers myset
1) "test1"
127.0.0.1:6379> smembers myset1
(empty list or set)
127.0.0.1:6379> smove myset myset1 test1
(integer) 1
127.0.0.1:6379> smembers myset1
1) "test1"

zset(有序集合)

Redis zset和set一样也是String类型元素的集合,且不允许重复的成员,不同的是每个元素都会关联一个double类型的分数,redis正是通过分数来为集合中的成员进行从小到大的排序的。

. ZADD: 添加多个元素到有序集合中

ZADD key [NX|XX] [CH] [INCR] score member [score member ...]
例如:127.0.0.1:6379> ZADD city:gdp 95 "beijing" 92 "shanghai" 89 "shengzhen"
(integer) 3

ZINCRBY: 为分数值加上增量

ZINCRBY key increment member
例如:127.0.0.1:6379> zincrby city:gdp 3 "beijing"
"98"

ZCARD:获取有序集合中的元素数量

ZCARD key
例如:127.0.0.1:6379> ZCARD city:gdp
(integer) 3

ZCOUNT: 获取在分数区间内的元素数量

zcount key min max
例如:127.0.0.1:6379>  zcount city:gdp 90 99
(integer) 2

ZREM: 删除有序集合中的多个元素

ZREM key member [member ..]
  例如:127.0.0.1:6379> zrem city:gdp "beijing"
(integer) 1

排序

sort 排序

sort mylist
例如:
127.0.0.1:6379> lpush mylist 1 2 3 4
(integer) 4
127.0.0.1:6379> lpush mylist 1 2 3 4 12 10 9
(integer) 11
127.0.0.1:6379> sort mylist
 1) "1"
 2) "1"
 3) "2"
 4) "2"
 5) "3"
 6) "3"
 7) "4"
 8) "4"
 9) "9"
10) "10"
11) "12"

字母排序

sort mylist alpha desc limit 0 2

总结

本文主要介绍了Redis中各种常见的命令,Redis 有五种数据类型,每种数据类型都有不同的操作命令。

相关文章
|
5月前
|
存储 缓存 监控
Redis设计与实现——Redis命令参考与高级特性
Redis 是一个高性能的键值存储系统,支持丰富的数据类型(字符串、列表、哈希、集合等)和多种高级功能。本文档涵盖 Redis 的核心命令分类,包括数据类型操作、事务与脚本、持久化、集群管理、系统监控等。特别介绍了事务的原子性特性、Lua 脚本的执行方式及优势、排序机制、发布订阅模型以及慢查询日志和监视器工具的使用方法。适用于开发者快速掌握 Redis 常用命令及其应用场景,优化系统性能与可靠性。
|
21天前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
61 12
|
20天前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
2月前
|
存储 缓存 人工智能
Redis六大常见命令详解:从set/get到过期策略的全方位解析
本文将通过结构化学习路径,帮助读者实现从命令语法掌握到工程化实践落地的能力跃迁,系统性提升 Redis 技术栈的应用水平。
|
3月前
|
NoSQL Redis
Lua脚本协助Redis分布式锁实现命令的原子性
利用Lua脚本确保Redis操作的原子性是分布式锁安全性的关键所在,可以大幅减少由于网络分区、客户端故障等导致的锁无法正确释放的情况,从而在分布式系统中保证数据操作的安全性和一致性。在将这些概念应用于生产环境前,建议深入理解Redis事务与Lua脚本的工作原理以及分布式锁的可能问题和解决方案。
132 8
|
5月前
|
存储 缓存 NoSQL
Redis中的常用命令-get&set&keys&exists&expire&ttl&type的详细解析
总的来说,这些Redis命令提供了处理存储在内存中的键值对的便捷方式。通过理解和运用它们,你可以更有效地在Redis中操作数据,使其更好地服务于你的应用。
357 17
|
5月前
|
消息中间件 NoSQL Linux
Redis的基本介绍和安装方式(包括Linux和Windows版本),以及常用命令的演示
Redis(Remote Dictionary Server)是一个高性能的开源键值存储数据库。它支持字符串、列表、散列、集合等多种数据类型,具有持久化、发布/订阅等高级功能。由于其出色的性能和广泛的使用场景,Redis在应用程序中常作为高速缓存、消息队列等用途。
844 16
|
5月前
|
JSON NoSQL Redis
在Rocky9系统上安装并使用redis-dump和redis-load命令的指南
以上步骤是在Rocky9上使用redis-dump和redis-load命令顺利出行的秘籍。如果在实行的过程中,发现了新的冒险和挑战,那么就像一个勇敢的航海家,本着探索未知的决心,解决问题并前进。
154 14
|
5月前
|
消息中间件 NoSQL Unix
Redis的基本特性以及其基础命令用法
这只是冰山一角,Redis的强大功能和简洁的操作方法值得我们深入了解和掌握,是复杂数据问题解决的有力工具。所以,来一场有趣的Redis冒险吧!
165 6
|
10月前
|
NoSQL 应用服务中间件 API
Redis是如何建立连接和处理命令的
本文主要讲述 Redis 是如何监听客户端发出的set、get等命令的。
1508 160