iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Redis数据操作
  • 351
分享到

Redis数据操作

2024-04-02 19:04:59 351人浏览 独家记忆
摘要

点击中⽂官⽹查看命令⽂档Http://Redis.cn/commands.htmlRedis命令操作:http://doc.redisfans.com/数据结构redis是key-value的数据结构,每条

点击中⽂官⽹查看命令⽂档Http://Redis.cn/commands.html

Redis命令操作:http://doc.redisfans.com/

数据结构

  • redis是key-value的数据结构,每条数据都是⼀个键值对

  • 键的类型是字符串

  • 注意:键不能重复

值的类型分为五种

  • 字符串string

  • 哈希hash

  • 列表list

  • 集合set

  • 有序集合zset

数据操作行为

  • 保存

  • 修改

  • 获取

  • 删除

点击中⽂官⽹查看命令⽂档http://redis.cn/commands.html

RDB报错以及解决

MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error.

Redis被配置为保存数据库快照,但它目前不能持久化到硬盘。用来修改集合数据的命令不能用

原因:

  • 强制关闭Redis快照导致不能持久化。 解决方案:

  • 运行config set stop-writes-on-bgsave-error no 命令后,关闭配置项stop-writes-on-bgsave-error解决该问题。


键命令

  • 查找键,参数⽀持正则表达式

      keys pattern

  • 例1:查看所有键

      keys *

      例2:查看名称中包含a的键

        keys 'a*'

  •      判断键是否存在,如果存在返回1,不存在返回0

     exists key1

  • 例3:判断键a1是否存在

      exists a1

  •      查看键对应的value的类型

     type key

  • 例4:查看键a1的值类型,为redis⽀持的五种类型中的⼀种

     type a1

  •     删除键及对应的值

     del key1 key2 ...

  • 例5:删除键a2、a3

     del a2 a3

  • 设置过期时间,以秒为单位

  • 如果没有指定过期时间则⼀直存在,直到使⽤DEL移除

    expire key seconds

  • 例6:设置键'a1'的过期时间为3秒

    expire 'a1' 3

  • 查看有效时间,以秒为单位

    ttl key

  • 例7:查看键'bb'的有效时间

    ttl bb





string类型

  • 字符串类型是 Redis 中最为基础的数据存储类型,它在 Redis 中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或JSON对象描述信息等。在Redis中字符串类型的Value最多可以容纳的数据长度是512M。

保存

如果设置的键不存在则为添加,如果设置的键已经存在则修改

  • 设置键值

    set key value

  • 例1:设置键为name值为itcast的数据

    set name itcast

  • 设置键值及过期时间,以秒为单位

    setex key seconds value

  • 例2:设置键为aa值为aa过期时间为3秒的数据

    setex aa 3 aa

  • 设置多个键值

    mset key1 value1 key2 value2 ...

  • 例3:设置键为'a1'值为'python'、键为'a2'值为'java'、键为'a3'值为'c'

    mset a1 Python a2 java a3 c

  • 追加值

    append key value

  • 例4:向键为a1中追加值' haha'

    append 'a1' 'haha'

获取

  • 获取:根据键获取值,如果不存在此键则返回nil

    get key

  • 例5:获取键'name'的值

    get 'name'

  • 根据多个键获取多个值

    mget key1 key2 ...

  • 例6:获取键a1、a2、a3'的值

    mget a1 a2 a3

删除

     删除键时会将值删除





hash类型

  • hash⽤于存储对象,对象的结构为属性、值

  • 值的类型为string

增加、修改

  • 设置单个属性

    hset key field value

  • 例1:设置键 user的属性name为libai

    hset user name libai



  • 设置多个属性

    hmset key field1 value1 field2 value2 ...

  • 例2:设置键u2的属性name为itcast、属性age为11

    hmset u2 name laowang age 11


获取

  • 获取指定键所有的属性

    hkeys key

  • 例3:获取键u2的所有属性

    hkeys u2

  • 获取⼀个属性的值

    hget key field

  • 例4:获取键u2属性'name'的值

    hget u2 'name'

  • 获取多个属性的值

    hmget key field1 field2 ...

  • 例5:获取键u2属性'name'、'age的值

    hmget u2 name age

  • 获取所有属性的值

    hvals key

  • 例6:获取键'u2'所有属性的值

    hvals u2




list类型

  • 列表的元素类型为string

  • 按照插⼊顺序排序

增加

  • 在左侧插⼊数据

    lpush key value1 value2 ...

  • 例1:从键为'a1'的列表左侧加⼊数据a 、 b 、c

    lpush a1 a b c

  • 在右侧插⼊数据

    rpush key value1 value2 ...

  • 例2:从键为'a1'的列表右侧加⼊数据0 1

    rpush a1 0 1

  • 在指定元素的前或后插⼊新元素

    linsert key before或after 现有元素 新元素

  • 例3:在键为'a1'的列表中元素'b'前加⼊'3'

    linsert a1 before b 3

获取

  • 返回列表⾥指定范围内的元素

    lrange key start stop

    • start、stop为元素的下标索引

    • 索引从左侧开始,第⼀个元素为0

    • 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素

  • 例4:获取键为'a1'的列表所有元素

    lrange a1 0 -1

设置指定索引位置的元素值

  • 索引从左侧开始,第⼀个元素为0

  • 索引可以是负数,表示尾部开始计数,如-1表示最后⼀个元素

    lset key index value

  • 例5:修改键为'a1'的列表中下标为1的元素值为'z'

    lset a 1 z

删除

  • 删除指定元素

    lrem key count value

    • 将列表中前count次出现的值为value的元素移除

    • count > 0: 从头往尾移除

    • count < 0: 从尾往头移除

    • count = 0: 移除所有

  • 例6.1:向列表'a2'中加⼊元素'a'、'b'、'a'、'b'、'a'、'b'

    lpush a2 a b a b a b

  • 例6.2:从'a2'列表右侧开始删除2个'b'

    lrem a2 -2 b

  • 例6.3:查看列表'py12'的所有元素

    lrange a2 0 -1







set类型

  • ⽆序集合

  • 元素为string类型

  • 元素具有唯⼀性,不重复

  • 说明:对于集合没有修改操作

增加

  • 添加元素

    sadd key member1 member2 ...

  • 例1:向键'a3'的集合中添加元素'zhangsan'、'lisi'、'wangwu'

    sadd a3 zhangsan sili wangwu

获取

  • 返回所有的元素

    smembers key

  • 例2:获取键'a3'的集合中所有元素

    smembers a3

删除

  • 删除指定元素

    srem key

  • 例3:删除键'a3'的集合中元素'wangwu'

    srem a3 wangwu




zset类型

  • sorted set,有序集合

  • 元素为string类型

  • 元素具有唯⼀性,不重复

  • 每个元素都会关联⼀个double类型的score,表示权重,通过权重将元素从⼩到⼤排序

  • 说明:没有修改操作


增加

  • 添加

    zadd key score1 member1 score2 member2 ...

  • 例1:向键'a4'的集合中添加元素'lisi'、'wangwu'、'zhaoliu'、'zhangsan',权重分别为4、5、6、3

    zadd a4 4 lisi 5 wangwu 6 zhaoliu 3 zhangsan

获取

  • 返回指定范围内的元素

  • start、stop为元素的下标索引

  • 索引从左侧开始,第⼀个元素为0

  • 索引可以是负数,表示从尾部开始计数,如-1表示最后⼀个元素

    zrange key start stop

  • 例2:获取键'a4'的集合中所有元素

    zrange a4 0 -1

  • 返回score值在min和max之间的成员

    zrangebyscore key min max

  • 例3:获取键'a4'的集合中权限值在5和6之间的成员

    zrangebyscore a4 5 6


  • 返回成员member的score值

    zscore key member

  • 例4:获取键'a4'的集合中元素'zhangsan'的权重

    zscore a4 zhangsan

删除

  • 删除指定元素

    zrem key member1 member2 ...

  • 例5:删除集合'a4'中元素'zhangsan'

    zrem a4 zhangsan

  • 删除权重在指定范围的元素

    zremrangebyscore key min max

  • 例6:删除集合'a4'中权限在5、6之间的元素

    zremrangebyscore a4 5 6






您可能感兴趣的文档:

--结束END--

本文标题: Redis数据操作

本文链接: https://www.lsjlt.com/news/39214.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • oracle怎么查询当前用户所有的表
    要查询当前用户拥有的所有表,可以使用以下 sql 命令:select * from user_tables; 如何查询当前用户拥有的所有表 要查询当前用户拥有的所有表,可以使...
    99+
    2024-05-14
    oracle
  • oracle怎么备份表中数据
    oracle 表数据备份的方法包括:导出数据 (exp):将表数据导出到外部文件。导入数据 (imp):将导出文件中的数据导入表中。用户管理的备份 (umr):允许用户控制备份和恢复过程...
    99+
    2024-05-14
    oracle
  • oracle怎么做到数据实时备份
    oracle 实时备份通过持续保持数据库和事务日志的副本来实现数据保护,提供快速恢复。实现机制主要包括归档重做日志和 asm 卷管理系统。它最小化数据丢失、加快恢复时间、消除手动备份任务...
    99+
    2024-05-14
    oracle 数据丢失
  • oracle怎么查询所有的表空间
    要查询 oracle 中的所有表空间,可以使用 sql 语句 "select tablespace_name from dba_tablespaces",其中 dba_tabl...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限设置
    答案:要创建 oracle 新用户,请执行以下步骤:以具有 create user 权限的用户身份登录;在 sql*plus 窗口中输入 create user identified ...
    99+
    2024-05-14
    oracle
  • oracle怎么建立新用户
    在 oracle 数据库中创建用户的方法:使用 sql*plus 连接数据库;使用 create user 语法创建新用户;根据用户需要授予权限;注销并重新登录以使更改生效。 如何在 ...
    99+
    2024-05-14
    oracle
  • oracle怎么创建新用户并赋予权限密码
    本教程详细介绍了如何使用 oracle 创建一个新用户并授予其权限:创建新用户并设置密码。授予对特定表的读写权限。授予创建序列的权限。根据需要授予其他权限。 如何使用 Oracle 创...
    99+
    2024-05-14
    oracle
  • oracle怎么查询时间段内的数据记录表
    在 oracle 数据库中查询指定时间段内的数据记录表,可以使用 between 操作符,用于比较日期或时间的范围。语法:select * from table_name wh...
    99+
    2024-05-14
    oracle
  • oracle怎么查看表的分区
    问题:如何查看 oracle 表的分区?步骤:查询数据字典视图 all_tab_partitions,指定表名。结果显示分区名称、上边界值和下边界值。 如何查看 Oracle 表的分区...
    99+
    2024-05-14
    oracle
  • oracle怎么导入dump文件
    要导入 dump 文件,请先停止 oracle 服务,然后使用 impdp 命令。步骤包括:停止 oracle 数据库服务。导航到 oracle 数据泵工具目录。使用 impdp 命令导...
    99+
    2024-05-14
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作