尚硅谷redis学习4-数据类型

  redis的数据类型包括String,Hash(类似于JAVA里的map),List,Set,Zset(sorted Set)

  String(字符串)
  string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
  string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
  string类型是Redis最基本的数据类型,一个redis中字符串value最多可以是512M

  Hash(哈希)
  Redis hash 是一个键值对集合。
  Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
  类似Java里面的Map<String,Object>

  List(列表)
  Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
  它的底层实际是个链表

  Set(集合)
  Redis的Set是string类型的无序集合。它是通过HashTable实现实现的

  zset(sorted set:有序集合)
  Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
  不同的是每个元素都会关联一个double类型的分数。
  redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的,但分数(score)却可以重复。

  www.redisdoc.com有全部命令

  

  但一般用不到这么多,我们可以看一下常用的

  Key

  String

  List

  Set

  Hash

  Zset

  下面再说一说必须掌握的一些命令

  Key

  String

  下面具体说说

  getrange/setrange

  从零到负一表示全部
 
  setrange

  设置指定区间范围内的值,格式是setrange key值 具体值

  setex/setnx

  setex:设置带过期时间的key,动态设置。
  setex 键 秒值 真实值

  setnx:只有在 key 不存在时设置 key 的值。

  mset/mget/msetnx

  mset:同时设置一个或多个 key-value 对。

  mget:获取所有(一个或多个)给定 key 的值。

  msetnx:同时设置一个或多个 key-value 对,当且仅当所有给定 key 都不存在。

  getset

  getset:将给定 key 的值设为 value ,并返回 key 的旧值(old value)。
  简单一句话,先get然后立即set

  List

  下面来具体说说

  lpop/rpop

  通过索引获取列表中的元素 lindex key index

  * 从left往right删除2个值等于v1的元素,返回的值为实际删除的数量
     *  LREM list3 0 值,表示删除全部给定的值。零个就是全部值

  ltrim:截取指定索引区间的元素,格式是ltrim list的key 起始索引 结束索引

  移除列表的最后一个元素,并将该元素添加到另一个列表并返回

  lset

  在list某个已有值的前后再添加具体值

  list insert key before/after value

  效率

  它是一个字符串链表,left、right都可以插入添加;
  如果键不存在,创建新的链表;
  如果键已存在,新增内容;
  如果值全移除,对应的键也就消失了。
  链表的操作无论是头和尾效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。

  Set

  sadd/smembers/sismember

  scard

  获取集合里面的元素个数

  srem key value 删除集合中的元素

  srandmember key num

  *   从set集合里面随机取出2个
   *   如果超过最大数量就全部取出,
   *   如果写的值是负数,比如-3 ,表示需要取出3个,但是可能会有重复值。

  spop key 随机出栈

  smove key1 key2

  sdiff

  在第一个set里面而不在后面任何一个set里面的项

  sinter

  sunion

  Hash

  常用

  kv模式不变,但v是一个键值对

  hset/hget/hmset/hmget/hgetall/hdel

  hlen:求长度

  hexists key value的key 看在一个hash中一个key是否存在

  hkeys/hvals

  hincrby/hincrbyfloat

  hsetnx

  Zset(sortedset):有序集合:是在set基础上,加一个score值,之前set是key v1 v2 v3,现在是key score1 v1 score2 v2 score3 v3

  zadd/zrange

  zrangebyscore

  zrem:删除元素

  删除元素,格式是zrem zset的key 项的值,项的值可以是多个

  zrem key score某个对应值,可以是多个值

  zcard/zcount/zrank/zscore

  zcard :获取集合中元素个数

  zcount :获取分数区间内元素个数,zcount key 开始分数区间 结束分数区间

  zrank: 获取value在zset中的下标位置

  zscore:按照值获得对应的分数

  zrevrank

  正序、逆序获得下标索引值

  zrevrange

  zrevrangebyscore

原文地址:https://www.cnblogs.com/liunianfeiyu/p/10217816.html

时间: 2024-10-09 07:09:11

尚硅谷redis学习4-数据类型的相关文章

尚硅谷redis学习1-NOSQL简介

本系列是自己学习尚硅谷redis视频的记录,防止遗忘,供以后用到时快速回忆起来,照抄视频和资料而已,没什么技术含量,仅给自己入门了解,我是对着视频看一遍再写的,视频地址如下:尚硅谷Redis视频 背景:传统型数据库面临的问题 传统型数据库架构的演变 从最开始的单机一路进化到缓存加集群加分库分表主从读书分离,但即使这样还是有问题得不到解决 今天最终已经成为了这个样子 为什么用NoSql NoSql更适合大数据的处理 特点 传统数据库的NoSql的比较 RDBMS - 高度组织化结构化数据 - 结构

尚硅谷redis学习1-NOSQL简介2

NoSql数据模型简介 聚合模型:KV键值,BSON 列族: 图形,这里的图形不是指真正的图形,而是关系图 NoSql数据库的四大分类 KV键值:BerkeleyDB,Redis,tair,memcache 文档型数据库:couchDB,mongoDB 列存储数据库:Cassandra,HBase,分布式文件系统 图关系数据库:Neo4J,InfoGrid 对比: 分布式数据库的CAP+BASE 传统的ACID:A(atom icity):原子性 C(Consistency):一致性 I(Iso

尚硅谷redis学习7-持久化AOF

AOF比RDB优点在于数据的实时性高,经过设置后最多只会损失一秒钟的数据,而RDB最多可能损失上次备份到此次DOWM机间的数据 原理 配置文件 设置同步频率 重启redis,测试,可以看到数据在关机重启后恢复了 处理aof文件损坏 给aof文件加异常字符 关闭redis后发现已无法启动 修复aof文件,可以看到修改aof文件后redis启动成功 小总结 重写rewrite 配置文件 优劣势 小总结 和rdb如何使用 性能建议 原文地址:https://www.cnblogs.com/liunia

尚硅谷redis学习8-事务

是什么? 能干嘛? 常用命令 案例说明 1.正常执行 2.放弃事务 3.全部放弃(全体连坐) 4.只抛弃错误(冤头债主) 5.watch监控 悲观锁 悲观锁(Pessimistic Lock), 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁.传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁 乐观锁 乐观锁(Optimistic Lock), 顾名思义,就

尚硅谷redis学习9-发布订阅

是什么? 图示说明 命令 例子 原文地址:https://www.cnblogs.com/liunianfeiyu/p/10317816.html

尚硅谷redis学习10-复制

是什么? 能干嘛? 怎么玩? 1) 初始情况 设置slave 日志查看 主机查看 备机日志 复制状态 觉见问题 1 切入点问题?slave1.slave2是从头开始复制还是从切入点开始复制?比如从k4进来,那之前的123是否也可以复制 从头复制 2 从机是否可以写?set可否?  从机是只读的 3 主机shutdown后情况如何?从机是上位还是原地待命  从机原地待命 4 主机又回来了后,主机新增记录,从机还能否顺利复制?  可以 5 其中一台从机down后情况如何?依照原有它能跟上大部队吗?

尚硅谷springboot学习14-自动配置原理

配置文件能配置哪些属性 配置文件能配置的属性参照 自动配置的原理 1).SpringBoot启动的时候加载主配置类,开启了自动配置功能 @EnableAutoConfiguration 2).@EnableAutoConfiguration 作用: 利用EnableAutoConfigurationImportSelector给容器中导入一些组件? 可以查看selectImports()方法的内容: List<String> configurations = getCandidateConfi

redis学习-sds数据类型

今天开始了redis的学习,本来想直接从源码看起的,不过看到有篇对redis介绍的基础教程 <Redis 设计与实现(第一版)> 于是决定从这个开始入门. 1.数据类型定义 typedef char *sds; struct sdshdr { // buf 已占用长度 int len; // buf 剩余可用长度 int free; // 实际保存字符串数据的地方 char buf[]; }; 2.重新计算新的长度 newlen = sdshdr.len + required_len if n

Redis学习之数据类型List详解

本文和大家分享的主要是redis数据类型中的list相关内容,一起来看看吧,希望对大家学习redis有所帮助. list即链表,它是一个能维持数据先后顺序的列表,便于在表的两端追加和删除数据,中间位置的存取具有O(N)的时间复杂度,是一个双向链表. 一.内部原理 redis内部实现代码在quicklist.c(注释:A doubly linked list of ziplists)中,它确实是一个双向链表,并且是一个ziplist双向列表. ziplist是什么? 一个经过特殊编码的的双向链表,