Redis(四)--- Redis的命令参考
1、简述
数据类型也称数据对象,包含字符串对象(string)、列表对象(list)、哈希对象(hash)、集合对象(set)、有序集合对象(zset)。
2、String数据类型命令
string 类型是redis最基础的数据类型,为简单key-value结构,并且value不限制类型,可以是数字,字符,图片等序列化对象,value值最大不可超过512M。
string类型在使用中经常用作分布式session共享,计数器,验证码过期,基础数据的缓存等。
在java编码中使用都是使用封装好的jar包,如spring redis,jedis等等,当封装的方法名称与命令行直接操作大同小异,下面展示命令行使用:
命令 | 用法 | 描述 |
set |
SET key value [EX seconds] [PX milliseconds] [NX|XX] |
|
get | GET key |
|
mset | MSET key value [key value ...] |
|
mget | MGET key [key ...] |
|
setex | SETEX key seconds value |
|
setnx | SETNX key value |
|
psetex | SETEX key milliseconds value |
|
getset | GETSET key value |
|
strlen | STRLEN key |
|
append | APPEND key value |
|
setrange | SETRANGE key offset value |
|
getrange | GETRANGE key start end |
|
incr | INCR key |
|
incrby | INCR key increment |
|
incrbyfloat | INCRBYFLOAT key increment |
|
decr | DECR key |
|
decrby | DECRBY key decrement |
|
msetnx | MSETNX key value [key value ...] |
|
注:redis的命令无大小写区分,但key值严格区分大小写
参数:
- EX seconds ---- 设置过期时间为秒,例:EX 60
- PX milliseconds ---- 设置过期时间为毫秒,例:PX 1000
- NX ---- 只有当key值不存在时才设置
- XX ---- 只有当key值存在时才设置
3、list数据类型命令
list数据类型为key-value键值对结构,但是其value值的结构为list,类似java中的队列;左侧为表头,右侧为表尾;结构类似于java的Map<String,List<Object>>
list数据类型可以作为消息队列使用,还可以作为排名等的缓存,也可以作为缓存分页。
命令 | 用法 | 描述 |
lpush |
LPUSH key value [value ...] |
|
lpushx | LPUSHX key value |
|
rpush | ROUSH key value [value ...] |
|
rpushx | RPUSHX key value |
|
lpop | LPOP key |
|
rpop | RPOP key |
|
rpoplpush | RPOPLPUSH source destination |
|
lrem | LREM key count value |
|
llen | LLEN key |
|
lindex | LINDEX key index |
|
linsert | LINSER key BEFORE|AFTER pivot value |
|
lset | LSET key index value |
|
lrange | LRANGE key start end |
|
ltrim | LTRIM key start end |
|
blpop | BLPOP key [key ...] timeout |
|
brpop | BRPOP key [key ...] timeout |
|
brpoplpush | BRPOPLPUSH source destination timeout |
|
4、hash数据类型
hash表数据类型是key-value结构,但是key为String类型,而value的结构则是field-value结构;类似于java中的Map<Sring,Map<Stirng,Object>> 结构。
hash表数据结构中field-value 的最大存储个数是 232 - 1 个;主要用途是作为key-value对象类型的缓存,在value中存储这个对象,取用时便于还原对象。
命令 | 用法 | 描述 |
hset | HSET key field value |
|
hsetnx | HSETNX key field value |
|
hget | HGET key field |
|
hexists | HEXISTS key field |
|
hdel | HDEL key field [field ...] |
|
hlen | HLEN key |
|
hstrlen | HSTRLEN key field |
|
hincrby | HINCRBY key field increment |
|
hincrbyfloat | HINCRBYFLOAT key field increment |
|
hmset | HMSET key field value [field value ...] |
|
hmget | HMGET key field [field ...] |
|
hkeys | HKEYS key |
|
hvals | HVALS key |
|
hgetall | HGETALL key |
|
5、set数据类型
set数据类型为无序集合数据类型,且数据不重复;
集合类型经常用户存储一些集合类型的数据,如微博的所有粉丝,标签等数据;结构类似java中的HashSet。
命令 | 用法 | 描述 |
sadd | SADD key value [value ...] |
|
sismember | SISMEMBER key value |
|
spop | SPOP key |
|
srandmember | SRANDMEMBER key [count] |
|
srem | SREM key value [value ...] |
|
smove | SMOVE source destination value |
|
scard | SCARD key |
|
smembers | SMEMBERS key |
|
sinter | SINTER key [key ...] |
|
sinterstore | SINTERSTORE destination key [key ...] |
|
sunion | SUNION key [key ...] |
|
sunionstore | SUNIONSTORE destination key [key ...] |
|
sdiff | SDIFF key [key ...] |
|
sdiffstore | SDIFFSTORE destination key [key ...] |
|
6、zset数据类型
zset数据类型为有序集合类型,且集合内元素不重复;
有集合通常被用作排行榜等有时间顺序或其他顺序的缓存集和;类似于java中的hashTable
命令 | 用法 | 描述 |
zadd | ZADD key score member [score member ...] |
|
zscore | ZSCORE key member |
|
zincrby | ZINCRBY key increment member |
|
zcard | ZCARD key |
|
zcount | ZCOUNT key min max |
|
zrange |
ZRANGE key start stop [WITHSCORE] |
|
zrevrange | ZREVRANGE key start top [WITHSCORE] |
|
zrangebyscore | ZRANGEBYSCORE key min max [WITHSOCRE] [LIMIT offset count] |
|
zrevrangebyscore | ZREVRANGEBYSCORE key min max [WITHSCORE] [LIMIT offset count] |
|
zrank | ZRANK key member |
|
zrevrank | ZREVRANK key member |
|
zrem | ZREM key member [member ...] |
|
zremrangebyrank | ZREMRANGEBYRANK key start stop |
|
zremrangebyscore | ZREMRANGEBYSCORE key min max |
|
zrangebylex | ZRANGEBYLEX key min max [LIMIT offset count] |
|
zlexcount | ZLEXCOUNT key min max |
|
zremrangebylex | ZREMRANGEBYLEX key min max |
|
7、redis 操作相关命令
redis除了对五大数据类型的操作命令,还有一些系统命令,可以对这个数据库进行操作,如删除key,清空数据库,手动持久化等。
命令 | 用法 | 描述 |
keys | KEYS pattern |
|
del | DEL key [key ...] |
|
exists | EXISTS key |
|
expire | EXPIRE key seconds |
|
expireat | EXPIREAT key seconds-timestamp |
|
pexpire | PEXPIRE key milliseconds |
|
pexpireat | PEXPIREAT key milliseconds-timestamp |
|
move | MOVE key db |
|
randomkey | RANDOMKEY |
|
persist | PERSIST key |
|
type | TYPE key |
|
rename | RENAME key newkey |
|
renamenx | RENAMENX key newkey |
|
dbsize | DBSIZE |
|
flushdb | FLUSHDB |
|
flushall | FLUSHALL |
|
select | SELECT index |
|
swapdb | SWAPDB db1 db2 |
|
ttl | TTL key |
|
pttl | PTTL key |
|
事物相关命令 |
||
multi | MULTI |
|
exec | EXEC |
|
discard | DISCARD |
|
watch | WATCH key [key ...] |
|
unwatch | UNWATCH |
|
持久化相关命令 |
||
save | SAVE |
|
bgsave | BGSAVE |
|
bgrewriteaof | BGREWRITEAOF |
|
lastsave | LASTSAVE |
|
作为队列使用相关命令(发布订阅) |
||
publish | PUBLISH channel message |
|
subscribe | SUBSCRIBE channel [channel ...] |
|
psubscribe | PSUBSCRIBE pattern [pattern ...] |
|
unsubscribe | UNSUBSCRIBE channel [channel ...] |
|
punsubscribe | PUNSUBSCRIBE pattern [pattern ...] |
|
pubsub |
PUBSUB channels [pattern ...] |
|
注:redis内部命令还有很多,有些维护之类的命令再次不做介绍,如果用到,请参考redis官网。
8、总结
Redis的命令大体上可以分为两种,一种可以称为数据库级命令,可以对任何键值操作,如:DEL、TYPE等,第7节说到的基本都是;另一种是针对五大数据类型操作的,以上几节说道的基本都是。
(1)命令类型检查
命令的执行之前,Reddis会先检查输入的key的类型是否正确,才会决定是否执行给定的命令,也就是命令与值类型是否匹配。
(2)多态命令
如前一章说过四种数据对象每种都有两种编码方式,但在本章使用的命令确是一个;Redis在执行命令之前,会判断对象的编码方式,然后再执行对应的命令,这就是命令的多状态。
参考:
《Redis设计与实现》黄健宏著,网上对Redis的详解等
此博客为笔者使用redis很久之后,参考网络上各类文章总结性书写,原创手打,如有错误欢迎指正。
Redis(四)--- Redis的命令参考的更多相关文章
- redis(四)redis与Mybatis的无缝整合让MyBatis透明的管理缓存
redis的安装 http://liuyieyer.iteye.com/blog/2078093 redis的主从高可用 http://liuyieyer.iteye.com/blog/207809 ...
- Redis 命令参考
Redis 命令参考 http://redis.readthedocs.org/en/latest/index.html
- redis命令参考和redis文档中文翻译版
找到了一份redis的中文翻译文档,觉得适合学习和查阅.这份文档翻译的真的很良心啊,他是<Redis 设计与实现>一书的作者黄健宏翻译的. 地址:http://redisdoc.com/i ...
- Redis命令参考之复制(Replication)
Redis 支持简单且易用的主从复制(master-slave replication)功能, 该功能可以让从服务器(slave server)成为主服务器(master server)的精确复制品. ...
- Redis介绍及常用命令
一 Redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发 ...
- redis 介绍和常用命令
redis 介绍和常用命令 redis简介 Redis 是一款开源的,基于 BSD 许可的,高级键值 (key-value) 缓存 (cache) 和存储 (store) 系统.由于 Redis 的键 ...
- redis的pub/sub命令
Redis 发布订阅 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息. Redis 客户端可以订阅任意数量的频道. 下图展示了频道 cha ...
- 四. Redis事务处理
Redis目前对事务的支持还是比较简单,Redis能保证一个Client发起的事务中的命令可以连续执行,而中间不会插入其他Client的命令:当一个Client在连接中发起一个multi命令的时候,这 ...
- 【redis】redis常用命令及操作记录
redis-cli是Redis命令行界面,可以向Redis发送命令,并直接从终端读取服务器发送的回复. 它有两种主要模式:一种交互模式,其中有一个REPL(read eval print loop), ...
随机推荐
- 事务 ( 进程 ID 60) 与另一个进程被死锁在锁资源上,并且已被选作死锁牺牲品
Select * FROM [TableName] With(NoLock) .....
- Python基础,day3
本节内容 1. 函数基本语法及特性 2. 参数与局部变量 3. 返回值 嵌套函数 4.递归 5.匿名函数 6.函数式编程介绍 7.高阶函数 8.内置函数 1.函数基本语法及特性 如何不重复代码,其实很 ...
- tensorflow学习笔记-bili莫烦
bilibili莫烦tensorflow视频教程学习笔记 1.初次使用Tensorflow实现一元线性回归 # 屏蔽警告 import os os.environ[' import numpy as ...
- 中转Webshell 绕过安全狗(一)
前言 听说中国菜刀里有后门.抓包我是没有监测到异常数据包.为了以防万一,且更好使用中国菜刀硬杠安全狗.笔者收集了一下资料.无耻的copy大佬的源码,只是在大佬的基础上简单修改了一下,达到Webshel ...
- ubuntu镜像快速下载
由于官网服务器在国外,下载速度奇慢,所以我们可以利用阿里云镜像下载ubuntu ubuntu 14.04: http://mirrors.aliyun.com/ubuntu-releases/14.0 ...
- JUnit-4.13使用报java.lang.NoClassDefFoundError: org/hamcrest/SelfDescribing错误
今天重新复习spring的时候,调用Junit架包来进行测试,进入其官网 https://junit.org/junit5/,点击右上角的Junit4进行查看 2.出现了的页面是这个样子 我把这个页 ...
- SqlHelper(基础)
using System; using System.Collections.Generic; using System.Data; using System.Data.SqlClient; usin ...
- 我竟然不再抗拒 Java 的类加载机制了
很长一段时间里,我对 Java 的类加载机制都非常的抗拒,因为我觉得太难理解了.但为了成为一名优秀的 Java 工程师,我决定硬着头皮研究一下. 01.字节码 在聊 Java 类加载机制之前,需要先了 ...
- POJ 1741:Tree(树上点分治)
题目链接 题意 给一棵边带权树,问两点之间的距离小于等于K的点对有多少个. 思路 <分治算法在树的路径问题中的应用> 图片转载于http://www.cnblogs.com/Paul-Gu ...
- 用链表和数组实现HASH表,几种碰撞冲突解决方法
Hash算法中要解决一个碰撞冲突的办法,后文中描述了几种解决方法.下面代码中用的是链式地址法,就是用链表和数组实现HASH表. he/*hash table max size*/ #define HA ...