Redis 支持丰富的数据格式,下面是 Redis 支持的数据格式列表:
- Binary-safe strings
- Lists
- Sets
- Sorted sets
- Hashes
- Bit arrays
- HyperLogLogs
在本节中我们讲解 Redis 的基本操作以及 String 类型相关操作。
Redis keys
这里是一些 Redis keys 的规则:
- redis keys 是二进制安全的。
- 太长的 key 不好
- 太短的 key 通常也不好
- 尝试定义一个 schema
- key 的最大长度是 512 MB
Redis Strings
strings 是 redis 中最简单的类型,也是 memcached 唯一的数据类型。(作者这么说是有一点小骄傲的意思)
打开 redis 目录中的 redis-cli 工具,我们来看一下 string 类型怎么用。
127.0.0.1:6379> set mykey somevalue OK 127.0.0.1:6379> get mykey "somevalue"
如上所示,使用 SET 和 GET 命令来存取 string 类型的值。注意 SET 会覆盖掉原有的值,即使后续 value 是一个空值也会把原来的值清空。
我们可以给 SET 命令加一个 nx 参数,指定 key 存在的时候 SET 操作失败;或者加一个 xx 参数,指定只有 key 已经存在的时候 SET 操作才会成功。
127.0.0.1:6379> set mykey newval nx (nil) 127.0.0.1:6379> get mykey "somevalue" 127.0.0.1:6379> set mykey2 newvalue xx (nil) 127.0.0.1:6379> set mykey newvalue xx OK
我们还可以把数字当字符串存储,redis 也为这种数值提供了一系列的原子操作(INCR、INCRBY、DECR、DECRBY 等)。
127.0.0.1:6379> set counter 100 OK 127.0.0.1:6379> get counter "100" 127.0.0.1:6379> incr counter (integer) 101 127.0.0.1:6379> incrby counter 50 (integer) 151
上述原子操作有效地解决了多个客户端的竞争问题。
GETSET 命令可以给一个 key 设置新值并返回旧值。一个典型的使用场景是计算网站的 pv:每次用户访问的时候,我们可以用 INCR 命令把计数器加一,如果我们要每个小时统计一次 pv,使用 GETSET 命令设置新值为 "0",这样就不会丢失任何一个访问请求了。
MSET 和 MGET 可以一次操作多个 key,对减小延迟很有好处(遗憾的是 codis 对这两个操作的支持不够好)
127.0.0.1:6379> mset a 10 b 20 c 30 OK 127.0.0.1:6379> mget a b c 1) "10" 2) "20" 3) "30"
对 Redis key 的操作
Redis 提供一些命令来操作 key,最有用的是 EXIST、DEL 和 TYPE 这三个。EXIST 用来判断一个 key 是否存在,DEL 命令可以删除一个 key,TYPE 命令可以查看这个 key 对应的 value 类型。
127.0.0.1:6379> set mykey hello OK 127.0.0.1:6379> exists mykey (integer) 1 127.0.0.1:6379> del mykey (integer) 1 127.0.0.1:6379> exists mykey (integer) 0 127.0.0.1:6379> set mykey x OK 127.0.0.1:6379> type mykey string 127.0.0.1:6379> del mykey (integer) 1 127.0.0.1:6379> type mykey none
过期时间
这里我们看下 Redis 的过期时间机制:你可以对每个 key 设置一个存活时间,这个时间到了 key 就会自动销毁,跟自动调用 DEL 命令删除的效果一样。
Redis 过期时间需要注意的几点:
- 支持以秒或毫秒为单位来设置过期时间
- Redis 系统对过期时间的解析精度总是毫秒
- 过期时间的信息是被多备份地存储在磁盘上,因此不受 Redis 服务器挂掉的影响。
127.0.0.1:6379> set key some-value OK 127.0.0.1:6379> get key "some-value" 127.0.0.1:6379> expire key 5 (integer) 1 127.0.0.1:6379> get key "some-value" 127.0.0.1:6379> get key (nil)
上例中我们用 EXPIRE 命令指定了 key 的过期时间是 5 秒,在两次 GET 命令期间,这个 key 自动销毁了。
我们还可以使用 PERSIST 命令把 key 的过期时间去掉。
另外我们在创建 key 的时候也可以直接指定过期时间,像这样:
127.0.0.1:6379> set key 100 ex 10 OK 127.0.0.1:6379> ttl key (integer) 8 127.0.0.1:6379> ttl key (integer) -2 127.0.0.1:6379> ttl key (integer) -2 127.0.0.1:6379> get key (nil)
上述例子设置了 key 的值为 100,过期时间是 10 秒,后续用 TTL 命令查看 key 的剩余存活时间,可以看到 key 过期之后存活时间一直显示为 -2(猜测是一种状态标识约定)。
使用 PEXPIRE 和 PTTL 命令可以执行精度为毫秒的对应操作,像下面这样:
127.0.0.1:6379> set key 100 OK 127.0.0.1:6379> get key "100" 127.0.0.1:6379> pexpire key 15000 (integer) 1 127.0.0.1:6379> ttl key (integer) 11 127.0.0.1:6379> pttl key (integer) 8523
相关推荐
Redis-Java是一款由Java语言实现的高性能缓存中间件,基于TCP实现客户端与服务端双向通信。 基本功能 客户端、服务端收发字节流 服务端解析字节流,执行命令 五大数据类型的命令、通用命令支持 RDB、AOF持久化机制...
二:Redis基本命令及常识 三:Key值命令 四:String(字符串)类型命令 五:Hash(哈希表)类型命令 六:List(集合)类型命令 七:Set(无序集合)类型命令 八:SortedSet(有序集合)类型命令 1:添加命令 2:查询...
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。这五种数据类型在内部的存储格式存在多种。
和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更...
因为它的 value 不仅包括基本的 string 类型还有 list,set ,sorted set 和 hash 类型。当 然这些类型的元素也都是 string 类型。也就是说 list,set 这些集合类型也只能包含 string 类型。你可以在这些类型上做很多...
Redis 数据类型Redis支持五种数据类型:String(字符串)string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个
以下是一个详细的Redis入门教程,它将帮助你理解Redis的基本概念、数据类型、常用命令以及一些高级特性。 ### 1. Redis简介 Redis(Remote Dictionary Server)是一个高性能的键值存储系统,支持多种类型的数据结构...
* redis共支持五种类型的数据 string,list,hash,set,sortedset * * string是最简单的字符串类型 * * list是字符串列表,其内部是用双向链表实现的,因此在获取/设置数据时可以支持正负索引 * 也可以将其当做...
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。 string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。 ...
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。 string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。 ...
因为它的value不仅包括基本的string类型还有list,set ,sorted set和hash类型。当然这些类型的元素也都是string类型。也就是说list,set这些集合类型也只能包含string 类型。你可以在这些类型上做很多原子性的操作。...
Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于...它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Hash), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型。
redis是一个以key-value存储的数据库结构型服务器,它支持的数据结构类型包括:字符串(String)、链表(lists)、哈希表(hash)、集合(set)、有序集合(Zset)等。为了保证读取的效率,redis把数据对象都存储在...
redis存储数据的基本类型有:string(字符串类型)、hash(散列类型)、list(列表类型)、set(集合类型)、zset(有序集合类型)。 依次做一些练习。redis命令不区分大小写。 key相关操作 127.0.0.1:6379> set ...
下一篇:C# Redis学习系列二:Redis基本设置 一.认识Redis 1. Redis 是一个高性能的key-value数据库。 2. 它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set –有序集合...
Redis 数据类型的详解 概要: Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set...string类型是Redis最基本的数据类型,一个键最大能存储512MB。 实例 redis 127.0.0.1:6379> SET name
2.redis数据类型 2.1.String 2.1.1.String操作 2.1.2.应用场景 2.2.hash 2.2.1.hash操作 2.2.3.应用场景 2.3.list 2.3.1list基本操作 2.3.3.应用场景 2.4.set 2.4.1.set基本操作 2.4.3.应用场景 2.5....
使用VS2017 ,管理包安装ServiceStack.Redis,然后可以使用。一些基本的例子支持的数据类型:string、list、set、sortedset
通过模板和特化技术实现 string/int 等不同索引类型的结果集 5. 开发 AbstractMongodbModule 类处理通用的 MongoDB 数据库表数据操作 数据库中不同的表都有自己的 AbstractMongodbModule 子类对应 6. 用 Perl 开发...