1 hashes 类型及操作

redis hash 是一个string 类型的 field 和 value 的映射表。他的添加、删除操作时间复杂度都是 O(1)

2 hset,设置 hash field 为指定值,如果 key 不存在,则先创建。

redis 127.0.0.1:> hset myhash field1 Hello
(integer)

3 hsetnx,设置 hash field 为指定值,如果 key 不存在,则先创建。如果 field 已经存在,返回 0,nx 是not exist 的意思。

redis 127.0.0.1:> hsetnx myhash field "Hello"
(integer)

4 hmset,同时设置 hash 的多个 field。

redis 127.0.0.1:> hmset myhash field1 Hello field2 World
OK

5 hget,获取指定的 hash field。

redis 127.0.0.1:> hget myhash field1
"Hello"

6 hmget,获取全部指定的 hash filed。

redis 127.0.0.1:> hmget myhash field1 field2 field3
) "Hello"
) "World"
) (nil)

7 hincrby,指定的 hash filed 加上给定值。

redis 127.0.0.1:> hset myhash field3
(integer)
redis 127.0.0.1:> hget myhash field3
""
redis 127.0.0.1:> hincrby myhash field3 -
(integer)
redis 127.0.0.1:> hget myhash field3
""

8 hexists,测试指定 field 是否存在。

redis 127.0.0.1:> hexists myhash field1
(integer)

9 hlen,返回指定 hash 的 field 数量。

redis 127.0.0.1:> hlen myhash
(integer)

10 hdel,删除指定 field,并返回指定 hash 的 field 数量。

redis 127.0.0.1:> hlen myhash
(integer)
redis 127.0.0.1:> hdel myhash field1
(integer)
redis 127.0.0.1:> hlen myhash
(integer)

11 hkeys,返回 hash 的所有 field。

redis 127.0.0.1:> hkeys myhash
) "field2"
) "field"
) "field3"

12 hvals,返回 hash 的所有 value。

redis 127.0.0.1:> hvals myhash
) "World"
) "Hello"
) ""

13 hgetall,获取某个 hash 中全部的 filed 及 value。

14 lists,Redis 的 list 类型其实就是一个每个子元素都是 string 类型的双向链表。链表的最大长度是(2的 32 次方)。我们可以通过 push,pop 操作从链表的头部或者尾部添加删除元素。这使得 list

既可以用作栈,也可以用作队列。

lpush,在 key 对应 list 的头部添加字符串元素

rpush,在 key 对应 list 的尾部添加字符串元素

linsert,在 key 对应 list 的特定位置之前或之后添加字符串元素,

redis 127.0.0.1:> rpush mylist3 "hello"
(integer)
redis 127.0.0.1:> rpush mylist3 "world"
(integer)
redis 127.0.0.1:> linsert mylist3 before "world" "there"
(integer)

lset,设置 list 中指定下标的元素值(下标从 0 开始)

lrem,从 key 对应 list 中删除 count 个和 value 相同的元素。count>0 时,按从头到尾的顺序删除。count=0 时,删除全部。

ltrim,保留指定 key 的值范围内的数据。

redis 127.0.0.1:> rpush mylist8 "one"
(integer)
redis 127.0.0.1:> rpush mylist8 "two"
(integer)
redis 127.0.0.1:> rpush mylist8 "three"
(integer)
redis 127.0.0.1:> rpush mylist8 "four"
(integer)
redis 127.0.0.1:> ltrim mylist8 -
OK
redis 127.0.0.1:> lrange mylist8 -
) "two"
) "three"
) "four"

lpop,从 list 的头部删除元素,并返回删除元素。

rpop,从 list 的尾部删除元素,并返回删除元素。

redis 127.0.0.1:> lrange mylist  -
) "hello"
) "world"
redis 127.0.0.1:> lpop mylist
"hello"
redis 127.0.0.1:> lrange mylist -
) "world"

rpoplpush,

从第一个 list 的尾部移除元素并添加到第二个 list 的头部,最后返回被移除的元素值,整个操作是原子的.如果第一个 list 是空或者不存在返回 nil。

redis 127.0.0.1:> lrange mylist5  -
) "three"
) "foo"
) "hello"
redis 127.0.0.1:> lrange mylist6 -
) "hello"
) "foo"
redis 127.0.0.1:> rpoplpush mylist5 mylist6
"hello"
redis 127.0.0.1:> lrange mylist5 -
) "three"
) "foo"
redis 127.0.0.1:> lrange mylist6 -
) "hello"
) "hello"
) "foo"

lindex,返回名称为 key 的 list 中 index 位置的元素

redis 127.0.0.1:> lrange mylist5  -
) "three"
) "foo"
redis 127.0.0.1:> lindex mylist5
"three"

llen,返回 key 对应 list 的长度

redis 127.0.0.1:> llen mylist5
(integer)

15 set

set 是集合,和我们数学中的集合概念相似,对集合的操作有添加删除元素,有对多个集合求交并差等操作,操作中 key 理解为集合的名字。

Redis 的 set 是 string 类型的无序集合。set 元素最大可以包含(2 的 32 次方)个元素。

set 的是通过 hash table 实现的,所以添加、删除和查找的复杂度都是 O(1)。

sadd,向名称为 key 的 set 中添加元素

srem,删除名称为 key 的 set 中的元素 member

redis 127.0.0.1:> sadd myset2 "one"
(integer)
redis 127.0.0.1:> sadd myset2 "two"
(integer)
redis 127.0.0.1:> sadd myset2 "three"
(integer)
redis 127.0.0.1:> srem myset2 "one"
(integer)
redis 127.0.0.1:> srem myset2 "four"
(integer)
redis 127.0.0.1:> smembers myset2
) "three"
) "two"

spop,随机返回并删除名称为 key 的 set 中一个元素

sdiff,返回所有给定 key 与第一个 key 的差集

sdiffstore,返回所有给定 key 与第一个 key 的差集,并将结果存为另一个 key

redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> sdiffstore myset4 myset2 myset3
(integer)
redis 127.0.0.1:> smembers myset4
) "three"

sinter,返回所有给定 key 的交集

redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> sinter myset2 myset3
) "two"

sinterstore,返回所有给定 key 的交集,并将结果存为另一个 key

sunion,返回所有给定 key 的并集

sunionstore,返回所有给定 key 的并集,并将结果存为另一个 key

smove,从第一个 key 对应的 set 中移除 member 并添加到第二个对应 set 中

redis 127.0.0.1:> smembers myset2
) "three"
) "two"
redis 127.0.0.1:> smembers myset3
) "two"
) "one"
redis 127.0.0.1:> smove myset2 myset7 three
(integer)
redis 127.0.0.1:> smembers myset7
) "three"

scard,返回名称为 key 的 set 的元素个数

sismember,测试 member 是否是名称为 key 的 set 的元素。

redis 127.0.0.1:> smembers myset2
) "two"
redis 127.0.0.1:> sismember myset2 two
(integer)
redis 127.0.0.1:> sismember myset2 one
(integer)

redis 基本类型的更多相关文章

  1. redis五大类型用法

    Redis五大类型:字符串(String).哈希/散列/字典(Hash).列表(List).集合(Set).有序集合(sorted set)五种Controller:@Resource RedisTe ...

  2. [置顶] Redis String类型数据常用的16条命令总结

    Redis String类型数据常用的16条命令总结 描述:String 类型是最简单的类型,一个Key对应一个Value,String类型是二进制安全的.Redis的String可以包含任何数据,比 ...

  3. Redis对象类型

    Redis对象类型 Redis基于基础的数据结构创建的对象: 字符串对象. 列表对象. 哈希对象. 集合对象 有序集合对象. 对象回收:Redis对象系统实现了基于引用计数技术的内存回收机制,当程序不 ...

  4. 一文了解:Redis基础类型

    Redis基础类型 Redis特点 开源的,BSD许可高级的key-value存储系统 可以用来存储字符串,哈希结构,链表,集合 安装 windows:https://github.com/micro ...

  5. Redis基础类型常用操作命令

    Redis基础类型常用操作命令 概念:Redis是用C语言开发的一个开源的高性能键值对数据库. 特征: 数据间没有必然的联系 内部采用单线程机制进行工作 高性能 多数据类型支持 字符串类型 Strin ...

  6. 分享一个Python脚本--统计redis key类型数据大小分布

    概述 今天主要介绍怎么统计redis key类型数据大小分布. 原理:使用redis命令: scan.pipline.type 和 debug object 来得到 redis key 信息. 脚本 ...

  7. redis字符串类型的基本命令

    1.redis字符串类型键的设置 命令名称:SET 语法:set key value [EX seconds] [PX milliseconds] [NX|XX] 功能:给一个key添加字符串类型的值 ...

  8. redis 五大类型 、持久化方式以及主从(哨兵模式)

    一.redis 五大类型: redis 键 keys * exists key的名字,判断某个key 是否存在 move key db 当前数据库就没有了,被移除了 ttl key 查看还有多少秒过期 ...

  9. Redis基本类型与常用命令

    Redis基本类型一共有五类: 字符串类型(string): 散列类型(hash): 列表类型(list): 集合类型(sort): 有序集合类型(zset): 在redis中,所有的类型都是被以键值 ...

  10. Redis学习笔记(3) Redis基础类型及命令之二

    1. 集合类型 集合类型与列表类型有很多相似之处,但二者的区别在于:前者具有唯一性,但不具有有序性:后者具有有序性,但不具有唯一性.集合类型的常用操作是向集合中加入或删除元素.判断某个元素是否存在等, ...

随机推荐

  1. FM遇到错误RQP-DEF-0354和QE-DEF-0144

    版本:Cognos 10.2.1 系统:Win10 操作过程:在FM调用了一个存储过程,其中引用了前端page页面的参数如下图所示,在验证和保存查询主题的时候一直提示参数没有替换值,错误 信息如下图所 ...

  2. DispatcherTimer

    1.IsEnabled 表示计时器是否已经启动. 2.DispatcherTimer处于当前线程的管理,不会新建一个线程专门用于计时操作,也就是说,当前线程可能会阻塞计时器.因此,Dispatcher ...

  3. Proguard随笔

    - ProGuard是一个压缩.优化和混淆Java字节码,它能够删除字节码中无用的类.字段.方法和无用的凝视,还能够对类.字段.方法和属性进行混淆. - 字节码事实上包括了大量的调试信息,从而非常ea ...

  4. springboot项目打包提示Unable to find a single main class from the following candidates错误

    提示Unable to find a single main class from the following candidates错误的原因是会从所有代码里面扫描包括main方法的类,找到多个类就报 ...

  5. iOS app集成支付宝支付流程及后台php订单签名处理

    iOS app集成支付宝支付流程 1: 开通支付宝商户 由公司去支付宝 https://b.alipay.com/order/serviceIndex.htm 签约支付宝开通支付宝商家: 2:商户支付 ...

  6. HDU 4620 Fruit Ninja Extreme 暴搜

    题目大意:题目就是描述的水果忍者. N表示以下共有 N种切水果的方式. M表示有M个水果需要你切. W表示两次连续连击之间最大的间隔时间. 然后下N行描述的是 N种切发 第一个数字C表示这种切法可以切 ...

  7. Java从零开始学二十三(集合Map接口)

    一.Map接口 Collection.Set.List接口都属于单值的操作,即:每次只能操作一个对象,而Map与它们不同的是,每次操作的是一对对象,即二元偶对象,Map中的每个元素都使用key à v ...

  8. HDU 2883 kebab(最大流)

    HDU 2883 kebab 题目链接 题意:有一个烧烤机,每次最多能烤 m 块肉.如今有 n 个人来买烤肉,每一个人到达时间为 si.离开时间为 ei,点的烤肉数量为 ci,每一个烤肉所需烘烤时间为 ...

  9. ThinkPHP的A方法,R方法,M方法,D方法区别

    在Thinkphp中,实例化对象有这么几种方法,如果是类,有A和R方法,区别是A方法只是对象的实例化,而R方法是可以同时实例化对象里面的方法的,这里需要去指定,如下面的实例代码: <?php n ...

  10. JavaScript 纯粹对象

    JavaScript 纯粹对象 1.定义: 通过 "{}" 或者 "new Object" 创建的对象,像new Date(),new String()都不是纯 ...