redis的常用数据操作:
redis是key-value的数据结构,每条数据都是一个键值对。
键的类型是字符串并且键不能重复。
   redis最基本数据类型是string 所以下面的操作可以省略引号"" 编译器能够当作字符串来识别我们的命令 值的类型分为五种:
1 字符串string
2 哈希hash
3 列表list
4 集合set
5 有序集合zset string类型命令:
1 增加、修改: 如果设置的键不存在则添加,如果存在则修改
1.1 设置键值
set key value 例如: 添加键py1 值为gj
set "py1" "gj" 1.2 设置键值及过期时间:以秒为单位,过期后数据自动删除
setex key seconds value 例如:设置键py2 的值为hr 3秒后过期
setex "py2" 3 "hr" 1.3 设置多个键值:
mset key1 value1 key2 value2 .... 例如:设置键py3值为dx 键py4值为xd 键py5值为nd 键py6值为bg
mset "py3" "dx" "py4" "xd" "py5" "nd" "py6" "bg" 1.4 追加值: 在值后追加字符串
append key value 例如:向键py1 追加haha
append "py1" "haha" 2 获取:
2.1 根据键获取值,如果不存在返回null
get key 例如:获取py1的值
get "py1" 2.2 根据多个键,获取多个值
mget key1 key2 key3 ... 例如:获取py3 py4 py5 py6 的值
mget "py3" "py4" "py5" "py6" 3 删除:删除键的时候会删除值
del key1 key2 key3 ... 键命令:
1 查找键,参数通配符查找
keys patern 例如:查看所有的键
keys *
例如:查看所有包含a的键
keys "*a*" 2 判断键是否存在,存在返回1 否则返回0
exists key 例如: 判断py1键是否存在
exists "py1" 3 查看键对应的value的类型
type key 例如:查看py1的值的类型
type "py1" 4 删除键对应的值
del key1 key2 .... 例如:删除键'py3'、'py4'、'py5'、'py6'
del 'py3' 'py4' 'py5' 'py6' 5 设置过期时间,以秒为单位。如果没有指定过期时间,则一直存在,直到使用del移除
expire key seconds 例如:设置py1的过期时间为10秒
expire "py1" 10 6 查看有效时间 秒为单位,已经失效则返回-2
ttl key 例如:查看py2的有效时间
ttl py2 hash类型命令:
hash用于存储对象,对象结构为属性、值。即 键值对中值是属性、值的组合。值的类型是string
1 增加、修改
1.1 设置单个属性
hset key field value 例如:设置py2的属性name为hr
hset "py2" name hr 1.2 设置多个属性
hmset key field1 value1 field2 value2 ... 例如:设置py3的属性name为dx 属性gender为1 属性birthday为2017-1-1
hmset py3 name dx gender 1 birthday 2017-1-1
2 获取
2.1 获取指定键的所有属性
hkeys key 例如:获取py3的所有属性
hkeys py3 2.2 获取一个属性的值
hget key field 例如:获取py2属性name的值
hget py2 name 2.3 获取多个属性值
hmget key field1 field2 .... 例如:获取py3属性name gender 和birthday
hmget py3 name gender birthday 2.4 获取所有属性
hvals key 例如:获取py3的所有属性的值
hvals py3 3 删除:
3.1 删除整个hash键值使用del命令
del key
3.2 删除属性
hdel key field1 field2... 例如:删除py3的属性gender birthday
hdel py3 gender birthday list类型命令:
列表的元素类型为string
按照插入顺序排序 1 增加
1.1 在左侧插入数据
lpush key value1 value2 ... 例如:从键py11的左侧插入数据dx xd
lpush py11 dx xd 1.2 在右侧插入数据
rpush key value1 value2 ... 例如:从py11右侧插入nd bg
rpush py11 nd bg 1.3 在指定元素的前或后插入新元素
linsert key before/after 现有元素 新元素 例如:在py11的列表中nd前加入zbt
linsert py11 before nd zbt 2 获取
2.1 返回列表里指定范围元素:
start、stop为元素的下表索引
索引从左侧开始第一个元素为0
索引可以使负数,从尾部开始,-1代表最后一个元素
lrange key start stop 例如:获取py11的列表所有元素
lrange py11 0 -1 3 删除
3.1 删除指定元素:
将表中前count次出现的值为value的元素全都移除
count>0从头开始往尾移除
count<0从尾开始向头移除
count=0移除所有
lrem key count value 例如:向列表'py12'中加入元素'h0'、'h1'、'h2'、'h0'、'h1'、'h3'、'h0'、'h1'
rpush list3 'h0' 'h1' 'h2' 'h0' 'h1' 'h3' 'h0' 'h1'
从'py12'列表右侧开始删除2个'h0'
lrem py12 -2 h0
查看列表'py12'的所有元素
lrange 'py12' 0 -1 set类型命令:
无序集合,元素为string类型,元素唯一。
对于集合没有修改操作。 1 增加 添加元素
sadd key member1 member2 ... 例如:向py21的集合里添加元素 yg xin yzp
sadd py21 yg xin yzp 2 获取 返回所有的元素
smembers key 例如:获取py21的所有元素
smembers py21 3 删除 删除指定元素
srem key member 例如:删除py21中的yzp
srem py21 yzp zset类型命令:
sorted set 有序集合,元素为string,元素唯一
每个元素有一个double类型的score,表示权重,zset内元素会按照权重从小到大排序
zset没有修改操作 1 增加
zadd key score1 member1 score2 member2 ... 例如:向py31集合中添加gj hr yg xin 权重分别是1 5 8 3
zadd py31 1 gj 5 hr 8 yg 3 xin 2 获取
2.1 返回指定范围内的元素
start stop为元素下标,左边第一个为0,右边第一个为-1
zrange key start stop 例如:获取py31的所有元素
zrange py31 0 -1 2.2 返回score值在min和max之间的成员
zrangebyscore key min max 例如:返回py31集合中权值在4到9之间的数据
zrangebyscore py31 4 9 2.3 返回成员member的score值
zscore key member 例如查看py31中yg的权值
zscore py31 yg 3 删除:
3.1 删除指定元素
zrem key member1 member2 ... 例如:删除py31中的yg
zrem py31 yg 3.2 删除权重在指定范围内的元素
zremrangebyscore key min max 例如:删除py31中权值在4到9之间的元素
zremrangebyscore py31 4 9

redis数据库各种数据类型的增删改查命令的更多相关文章

  1. 使用控制台对Redis执行增删改查命令

    使用控制台对Redis执行增删改查命令 在上一篇里,我们已经安装了redis.这一篇我们将一起来学习如何使用"控制台"管理Redis 首先肯定是打开一个控制台,在windows系统 ...

  2. Redis的增删改查命令总结与持久化方式

    原文:Redis的增删改查命令总结与持久化方式 Redis是用C语言实现的,一般来说C语言实现的程序"距离"操作系统更近,执行速度相对会更快. Redis使用了单线程架构,预防了多 ...

  3. MySQL数据库之表的增删改查

    目录 MySQL数据库之表的增删改查 1 引言 2 创建表 3 删除表 4 修改表 5 查看表 6 复制表 MySQL数据库之表的增删改查 1 引言 1.MySQL数据库中,数据库database就是 ...

  4. sqlite数据库操作详细介绍 增删改查,游标

    sqlite数据库操作详细介绍 增删改查,游标     本文来源于www.ifyao.com禁止转载!www.ifyao.com Source code     package com.example ...

  5. 如何创建数据库以及MySQL增删改查命令的简单运用

    在已经安装好MySQL的前提下 1.在Windows打开命令提示符窗口,输入命令启动MySQL命令行工具并登入root用户:mysql -h localhost -u root -p 2.输入密码后, ...

  6. Delphi - cxGrid连接Oracle数据库 实现数据的增删改查

    cxGrid连接Oracle数据库 实现数据的增删改查 cxGrid连接Oracle数据库 1:通过OraSession连接数据库.OraDataSet实现OraSession和OraDataSour ...

  7. 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理

    一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...

  8. mongodb windows的安装方法和添加到任务管理器中、检测是否成功、增删改查命令

    转: mongodb安装方法: https://blog.csdn.net/heshushun/article/details/77776706        mongodb检测安装成功 .以及增删改 ...

  9. zkCli的使用 常用的节点增删改查命令用法

    zkCli的使用 常用的节点增删改查命令用法 1. 建立会话  命令格式:zkCli.sh -timeout 0 -r -server ip:port ./zkCli.sh -server -time ...

随机推荐

  1. Python3基础教程2——Python的标准数据类型

    2018年3月12日 这次介绍一些python里面的标准数据类型 当然还是推荐一个比较系统的教程 http://www.runoob.com/python3/python3-tutorial.html ...

  2. tp框架的url模式

    tp框架url地址可以由以下四种 http://网址/index.php?m=XX&c=XX&a=XX   基本get模式 http://网址/index.php/模块/控制器/操作方 ...

  3. 云计算---openstack实例共享80、443端口

    前言 因为openstack使用的是apache,所以不能共享80端口,但创建的许多云主机,虽然可以通过rinetd进行跳转,但有时需要直接访问80端口,所以这里我们选择包含了nginx的openre ...

  4. SpringCache @Cacheable 在同一个类中调用方法,导致缓存不生效的问题及解决办法

    由于项目需要使用SpringCache来做一点缓存,但自己之前没有使用过(其实是没有听过)SpringCache,于是,必须先学习之. 在网上找到一篇文章,比较好,就先学习了,地址是: https:/ ...

  5. 关于脱离laravel框架使用Illuminate/Validation验证器

    1.关于Illuminate/Validation验证器 Validation 类用于验证数据以及获取错误消息. github地址:github.com/illuminate/validation 文 ...

  6. 基于JavaMail向邮箱发送邮件

    参考:http://blog.csdn.net/ghsau/article/details/17839983 http://blog.csdn.net/never_cxb/article/detail ...

  7. 走近webpack(1)--多入口及devServer的使用

    上一篇文章留下了一些问题,如果你没看过上一篇文章,可以在我的博客里查找,或者直接从这篇文章开始也是没问题的. const path = require('path'); module.exports= ...

  8. 笔记:MyBatis XML配置详解

    MyBatis 的配置文件包含了影响 MyBatis 行为甚深的设置(settings)和属性(properties)信息.文档的顶层结构如下: configuration 配置 properties ...

  9. Myeclipse快速补充返回值快捷键

    比如 image.getGraphics(); 按ALT+Shift+L键,弹出一个确认变量名称框,确认之后会补全语句Graphics graphics = image.getGraphics();

  10. 用SpringBoot搭建简单电商项目 01

    前几节呢,我们已经简单介绍了SpringBoot框架的使用,从这一节开始,我们尝试着使用SpringBoot框架来一步一步搭建一个简单电商项目.当然了,这不是真正的电商项目,你可以看成是一个CRUD案 ...