redis基本操作介绍
一、字符串
单个设置:set key value,如果key不存在则设置键值对,如果存在则修改
批量设置:mset key1 value1 [key2 value2]
单个获取:get key,如果key不存在返回结果为nil
批量获取:mget key1 [key2]
获取并修改:getset key value,如果key存在则修改值为value并返回key的原值,如果key不存在则设置key的值为value且返回值为nil
查询:keys 正则匹配,例如keys *
删除:del key,如果存在则返回删除的个数,不存在则反馈0
append key var:在key的值后面拼接字符串var,如果key不存在则相当于set,例如name值为Alice,则append name es后name的值为Alicees
getrange key start end:返回子串,字符串其实从0开始,包括开始和结束,例如hobby值为basketball,getrange hobby 2 5返回sket
strlen key:反馈key的值的长度
incr key:incr表示+1,如果key不存在则默认初始值为0,然后+1;如果key存在且为整数,则值+1;如果key存在且不为整数,则报错
decr key:decr表示-1,用法类似incr
incrby key n:incrby步长为n表示+n,用法类似incr
decrby key n:做减法-n,用法类似incrby
二、哈希
单个设置:hset obj key value
批量设置:hmset obj key1 value1 [key2 value2]...
单个获取:hget obj key
批量获取:hmget obj key1 [key2]...
获取所有:hgetall obj,返回所有的key和对应的值
删除key:hdel obj key1 [key2]
删除哈希:del obj
判断hash中是否存在某个key:hexists obj key,1表示存在0表示不存在
获取key的个数:hlen obj
获取所有key:hkeys obj
获取所有key的值:hvals obj
三、列表
列表有顺序,即有下标,下标从0开始,0表示左边第一位(头部),-1表示右边第一位(尾部)。
从左边插入元素:lpush mylist value1 [value2]
从右边插入元素:rpush mylist value1 [value2]
移出并获取左边第一个元素:lpop mylist
移出并获取右边第一个元素:rpop mylist
查看指定索引范围的元素:lrange mylist start end,start和end分别表示起始和结束索引,常用lrange mylist 0 -1查看整个列表
查看指定索引的元素:lindex mylist index,index表示索引位置
获取列表长度:llen mylist
设置指定索引元素的值:lset mylist index value
从左边开始在第一个指定元素前/后插入元素:linsert mylist before/after value1 value2,即从左开始在第一个value1前/后插入value2
保留指定索引范围的元素:ltrim mylist start stop,start和end分别表示起始和结束索引
删除列表:del mylist
lrem mylist count value:count为数量,value为元素,表示删除count个value,分为三种情况:
count为正数:从左边开始删除,删除count个value
count为负数:从右边开始删除,删除|count|个value
count为0:删除所有的value
rpoplpush mylist1 mylist2:将mylist1右边的第一个元素移除,并且添加到mylist2的左边
四、集合
向集合中添加成员:sadd myset value1 [value2 ...]
获取集合所有成员:smembers myset
统计集合成员数量:scard myset
判断成员是否属于集合:sismember myset value
随机返回成员:srandmember myset [n],默认随机返回集合中的一个成员(不是删除)
随机删除成员:spop myset [n],默认随机删除一个,参数n表示随机删除n个,如果n超过成员个数则集合清空不会报错
删除指定成员:srem myset value1 [value2 ...]
移动成员:smove myset1 myset2 value,将myset1中的成员移动到myset2中
返回多个集合的交集:sinter myset1 myset2 [myset3 ...]
返回多个集合的并集:sunion myset1 myset2 [myset3 ...]
返回多个集合的差集:sdiff myset1 myset2 [myset3 ...],即myset1 - myset2 [ - myset3]
返回多个集合的交集的元素个数并将成员存储到指定集合中:sinterstore destition myset1 myset2 [myset3 ...]
返回多个集合的并集的元素个数并将成员存储到指定集合中:sunionstore destition myset1 myset2 [myset3 ...]
返回多个集合的差集的元素个数并将成员存储到指定集合中:sdiffstore destition myset1 myset2 [myset3 ...]
redis基本操作介绍的更多相关文章
- 三、Redis基本操作——List
小喵的唠叨话:前面我们介绍了Redis的string的数据结构的原理和操作.当时我们提到Redis的键值对不仅仅是字符串.而这次我们就要介绍Redis的第二个数据结构了,List(链表).由于List ...
- 二、Redis基本操作——String(实战篇)
小喵万万没想到,上一篇博客,居然已经被阅读600次了!!!让小喵感觉压力颇大.万一有写错的地方,岂不是会误导很多筒子们.所以,恳请大家,如果看到小喵的博客有什么不对的地方,请尽快指正!谢谢! 小喵的唠 ...
- 一、Redis基本操作——String(原理篇)
小喵的唠叨话:最近京东图书大减价,小喵手痒了就买了本<Redis设计与实现>[1]来看看.这里权当小喵看书的笔记啦.这一系列的模式,主要是先介绍Redis的实现原理(可能很大一部分会直接照 ...
- Redis基本操作——List
Redis基本操作——List(原理篇) 学习过数据结构的同学,一定对链表(Linked List)十分的熟悉.相信我们自己也曾经使用过这种数据结构. 链表分为很多种:单向链表,双向链表,循环链表,块 ...
- Redis(二):Redis入门介绍
Redis入门介绍目录导航: 入门概述 VMWare + VMTools千里之行始于足下 Redis的安装 Redis启动后杂项基础知识讲解 入门概述 是什么 Redis:REmote DIction ...
- [转] Redis系统性介绍
Redis系统性介绍 http://blog.nosqlfan.com/html/3139.html?ref=rediszt 虽然Redis已经很火了,相信还是有很多同学对Redis只是有所听闻或者了 ...
- Redis基本操作-20150608
Redis基本操作-20150608 [http://my.oschina.net/u/241255/blog/206991] Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存 ...
- 【原】Redis基本操作
Redis基本操作 遍历操作 Pub-Sub server Lua脚本 Redis中的这些操作都是不分大小写的. 除了针对于具体类型的具体操作.还有一些其他操作. 遍历操作 SCAN cursor [ ...
- PyQuery基本操作介绍
PyQuery基本操作介绍 PyQuery为Python提供一个类似于jQuery对HTML的操作方式,可以使用jQuery的语法对html文档进行查询操作. 本文以百度首页为例来介绍PyQuery的 ...
随机推荐
- oracle如何实现自增?----用序列sequence的方法来实现
将表t_user的字段ID设置为自增:(用序列sequence的方法来实现) ----创建表 Create table t_user( Id number(6),userid varchar2(2 ...
- 再探JVM内存模型
以前学JVM的时候看过<深入理解JVM>,当时看的很模糊也记了些笔记,更像是为了应付面试.事实是确实把笔记都背上了,春招找实习的时候,内存管理.类加载.垃圾回收三连背一遍.后来自己做项目的 ...
- salesman,动态规划带一点点贪心。
题目直接链接 分析一下: 这题题意还是比较明白的(少见的一道中文题),他的意思就是:有这么一个无向图:保证联通且点与点直接有唯一的简单路径(说白了就是棵树,根节点是1),每个节点有一个权值(有正有负) ...
- 我终于弄懂了Python的装饰器(一)
此系列文档: 1. 我终于弄懂了Python的装饰器(一) 2. 我终于弄懂了Python的装饰器(二) 3. 我终于弄懂了Python的装饰器(三) 4. 我终于弄懂了Python的装饰器(四) 一 ...
- 二叉树的深度(剑指offer-38)
题目描述 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 递归解析: 思路: 从根节点出发,查询左子树的深度,获取右子树的深度 ...
- [JAVA]使用字节流拷贝文件
import java.io.*; /** * @Description: * @projectName:JavaTest * @see:PACKAGE_NAME * @author:郑晓龙 * @c ...
- web 安全之页面解析的流程学习
0x00 任务内容: 理解域名解析的整个过程 理解 web 页面请求的整个流程,绘制流程图(nginx 处理的 11 个过程) 学习 http 协议中的字段及含义 学习 http 请求方法以及返回状态 ...
- nuxt.js使用scss
1>安装一些loader npm i node-sass sass-loader scss-loader --save-dev 2>在nuxt.config.js中配置(需要全局使用的sc ...
- MYSQL 之 JDBC(十): JDBC的元数据
可以从Connection对象中获得有关数据库管理系统的各种信息 获取这些信息的方法都是在DatabaseMetaData类中. DatabaseMetaData:描述数据库的元数据对象 Result ...
- scrapy 基础组件专题(一):scrapy框架中各组件的工作流程
Scrapy 使用了 Twisted 异步非阻塞网络库来处理网络通讯,整体架构大致如下(绿线是数据流向): Scrapy主要包括了以下组件: 引擎(Scrapy)用来处理整个系统的数据流处理, 触发事 ...