【Redis 初阶】Redis 常见数据类型(Set、Zset、渐进式遍历、数据库管理)

一、Set 集合

集合类型也是保存多个字符串类型的元素的(可以使用 json 格式让 string 也能存储结构化数据),但和列表类型不同的是,集合中:

  1. 元素之间是无序的。(此处的 “无序” 是和 list 的有序相对应的)
  2. 元素不允许重复,如下图所示。

集合类型:

一个集合中最多可以存储个元素。Redis 除了支持集合内的增删查改操作,同时还支持多个集合取交集、并集、差集,合理地使用好集合类型,能在实际开发中解决很多问题。

  • list:[1, 2, 3] 和 [2, 1, 3] 是两个不同的 list
  • set:[1, 2, 3] 和 [2, 1, 3] 是同一个集合

1、普通命令

(1)SADD

将⼀个或者多个元素添加到 set 中。

注意:重复的元素无法添加到 set 中。

语法:

SADD key member [member ...]

命令有效版本:

1.0.0 之后

时间复杂度:

O(1)

返回值:

本次添加成功的元素个数。

示例:


(2)SMEMBERS

获取一个 set 中的所有元素,注意,元素间的顺序是无序的。

语法:

SMEMBERS key

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 是集合中的元素个数。

返回值:

所有元素的列表。

示例:


(3)SISMEMBER

判断一个元素在不在 set 中。

语法:

SISMEMBER key member

命令有效版本:

1.0.0 之后

时间复杂度:

O(1)

返回值:

1 表示元素在 set 中。0 表示元素不在 set 中或者 key 不存在。

示例:


(4)SCARD

获取一个 set 的基数(cardinality),即 set 中的元素个数。

语法:

SCARD key

命令有效版本:

1.0.0 之后

时间复杂度:

O(1)

返回值:

set 内的元素个数。

示例:


(5)SPOP

从 set 中删除并返回⼀个或者多个元素。

注意:由于 set 内的元素是无序的,所以取出哪个元素实际是未定义行为,即可以看作随机的。

语法:

SPOP key [count] 

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 是 count

返回值:

取出的元素。

示例:


(6)SMOVE

将一个元素从源 set 取出并放入目标 set 中。

语法:

SMOVE source destination member 

命令有效版本:

1.0.0 之后

时间复杂度:

O(1)

返回值:

1 表示移动成功,0 表示失败。

示例:

针对上述情况,smove 不会视为出错,也会按照删除、插入来执行。


(7)SREM

将指定的元素从 set 中删除。

语法:

SREM key member [member ...]  

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 是要删除的元素个数.

返回值:

本次操作删除的元素个数。

示例:


2、集合间操作

交集(inter)、并集(union)、差集(diff)的概念如下图所示:

集合求交集、并集、差集:


(1)SINTER

获取给定 set 的交集中的元素。

语法:

SINTER key [key ...]

命令有效版本:

1.0.0 之后

时间复杂度:

O(N * M),N 是最小的集合元素个数,M 是最大的集合元素个数。

返回值:

交集的元素。

示例:


(2)SINTERSTORE

获取给定 set 的交集中的元素并保存到目标 set 中。

要想知道交集的内容,直接按照集合的方式访问目标 set 这个 key 即可。

语法:

SINTERSTORE destination key [key ...] 

命令有效版本:

1.0.0 之后

时间复杂度:

O(N * M),N 是最小的集合元素个数,M 是最大的集合元素个数。

返回值:

交集的元素个数。

示例:


(3)SUNION

获取给定 set 的并集中的元素。

语法:

SUNION key [key ...]  

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 给定的所有集合的总的元素个数。

返回值:

并集的元素。

示例:


(4)SUNIONSTORE

获取给定 set 的并集中的元素并保存到目标 set 中。

语法:

SUNIONSTORE destination key [key ...]

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 给定的所有集合的总的元素个数。

返回值:

并集的元素个数。

示例:


(5)SDIFF

获取给定 set 的差集中的元素。

语法:

SDIFF key [key ...]

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 给定的所有集合的总的元素个数。

返回值:

差集的元素。

示例:


(6)SDIFFSTORE

获取给定 set 的差集中的元素并保存到⽬标 set 中。

语法:

SDIFFSTORE destination key [key ...] 

命令有效版本:

1.0.0 之后

时间复杂度:

O(N),N 给定的所有集合的总的元素个数.

返回值:

差集的元素个数。

示例:


3、命令小结

下表总结了集合类型的常见命令:

集合类型命令:


4、内部编码

集合类型的内部编码有两种:

  • intset(整数集合):当集合中的元素都是整数并且元素的个数小于 set-max-intset-entries 配置(默认 512 个)时,Redis 会选用 intset 来作为集合的内部实现,从而减少内存的使⽤。
  • hashtable(哈希表):当集合类型无法满足 intset 的条件时,Redis 会使用 hashtable 作为集合的内部实现。

(1)当元素个数较少并且都为整数时,内部编码为 intset

(2)当元素个数超过 512 个,内部编码为 hashtable

(3)当存在元素不是整数时,内部编码为 hashtable

 


5、使用场景

场景一:集合类型比较典型的使用场景是标签(tag)。例如 A 用户对娱乐、体育板块比较感兴趣,B 用户对历史、新闻比较感兴趣,这些兴趣点可以被抽象为标签。有了这些数据就可以得到喜欢同一个标签的人,以及用户的共同喜好的标签,这些数据对于增强用户体验和用户黏度都非常有帮助。 例如一个电子商务网站会对不同标签的用户做不同的产品推荐。

下面的演示通过集合类型来实现标签的若干功能。

(1)给用户添加标签

sadd user:1:tags tag1 tag2 tag5
sadd user:2:tags tag2 tag3 tag5
...
sadd user:k:tags tag1 tag2 tag4

(2)给标签添加用户

sadd tag1:users user:1 user:3
sadd tag2:users user:1 user:2 user:3
...
sadd tagk:users user:1 user:4 user:9 user:28

(3)删除用户下的标签

srem user:1:tags tag1 tag5
...

(4)删除标签下的用户

srem tag1:users user:1
srem tag5:users user:1
...

(5)计算用户的共同兴趣标签

sinter user:1:tags user:2:tags

场景二:还可以使用 Set 来计算用户之间的共同好友(基于 “集合求交集”),基于此还可以做一些好友推荐。 

场景三:

使用 Set 还能统计 UV(去重)。一个互联网产品如何衡量用户量,用户规模呢?

主要的指标是以下两个方面:

  1. PV(Page View),用户每次访问该服务器都会产生一个 pv。
  2. UV(User View),每个用户访问服务器都会产生一个 uv,但是同一个用户多次访问并不会使 uv 增加。uv 需要按照用户进行去重,去重的过程就可以使用 Set 来实现。

二、Zset 有序集合

有序集合相对于字符串、列表、哈希、集合来说会有一些陌生。它保留了集合不能有重复成员的特点,但与集合不同的是,有序集合中的每个元素都有一个唯一的浮点类型的分数(score)与之关联,着使得有序集合中的元素是可以维护有序的,但这个有序不是用下标作为排序依据而是用这个分数。

Zset 的内部数据结构是跳表。

如下图所示,该有序集合显示了三国中的武将的武力。

有序集合:

有序集合提供了获取指定分数和元素范围查找、计算成员排名等功能,合理地利用有序集合,可以帮助我们在实际开发中解决很多问题。

有序集合中的元素是不能重复的,但分数允许重复。类比于一次考试之后,每个人一定有一个唯一的分数,但分数允许相同。

列表、集合、有序集合三者的异同点: 


1、普通命令

(1)ZADD

添加或者更新指定的元素以及关联的分数到 zset 中,分数应该符合 double 类型,+inf/-inf 作为正负极限也是合法的。注意:负无穷大不是无穷小,负无穷大的绝对值和无穷大是一样的。

ZADD 的相关选项:

  • XX:仅仅用于更新已经存在的元素(member),不会添加新元素。

  • NX:仅用于添加新元素(member),不会更新已经存在的元素。

  • LT:仅当新分数小于当前分数时才更新现有元素,不会阻止添加新元素。

  • GT:仅当新分数大于当前分数时才更新现有元素,不会阻止添加新元素。

  • CH:默认情况下,ZADD 返回的是本次添加的元素个数,但指定这个选项之后,就会还包含本次更新的元素的个数。

  • INCR:此时命令类似 ZINCRBY 的效果,将元素的分数加上指定的分数。此时只能指定⼀个元素和分数。

语法:

ZADD key [NX | XX] [GT | LT] [CH] [INCR] score member [score member ...]

member 和 score 称为是一个 "pair",类似于 C++ 里的 std::pair。不要把它们理解成 “键值对”(key - value pair),键值对中是有明确的 “角色区分”,一定是根据键 -> 值。而对于有序集合来说,既可以通过 member 找到对应的 score,也可以通过 score 找到匹配的 member。

命令有效版本:

1.2.0 之后

时间复杂度:

O(log(N))

返回值:

返回新增成功的元素个数。

示例:

如果修改的分数影响到了之前的顺序,就会自动的移动元素位置,保持原有的升序顺序不变:


(2)ZCARD

获取一个 zset 的基数(cardinality),即 zset 中的元素个数。

语法:

ZCARD key 

命令有效版本:

1.2.0 之后

时间复杂度:

O(1)

返回值:

zset 内的元素个数。

示例:


(3)ZCOUNT

返回分数在 min 和 max 之间的元素个数,默认情况下,min 和 max 都是包含的,如果不想要边界值,可以通过在边界值前加上 '(' 来排除。

语法:

ZCOUNT key min max

命令有效版本:

2.0.0 之后

时间复杂度:

O(log(N))

先根据 min 找到对应的元素,再根据 max 找到对应的元素,两次都是 O(log(N))。实际上,Zset 内部会记录每个元素当前的 “排行” / “次序”,查询到元素就直接知道了元素所在的 “次序”(下标),就可以直接把 max 对应的元素次序和 min 对应的元素次序做减法即可。

返回值:

满足条件的元素列表个数。

示例:


(4)ZRANGE

返回指定区间里的元素,分数按照升序。带上 WITHSCORES 可以把分数也返回。

语法:

ZRANGE key start stop [WITHSCORES]  

此处的 [start, stop] 为下标构成的区间,从 0 开始,支持负数。

命令有效版本:

1.2.0 之后

时间复杂度:

O(log(N)+M),N 是整个有序集合的元素个数,M 是 start - stop 区间内的元素个数。

返回值:

区间内的元素列表。

示例:

Redis 内部存储数据是按照二进制的方式存储的,意味着 Redis 服务器是不负责字符编码的,所以要把二进制对回到汉字需要客户端支持:


(5)ZREVRANGE

返回指定区间里的元素,分数按照降序。带上 WITHSCORES 可以把分数也返回。

备注:这个命令可能在 6.2.0 之后废弃,并且功能合并到 ZRANGE 中。

语法:

ZREVRANGE key start stop [WITHSCORES] 

命令有效版本:

1.2.0 之后

时间复杂度:

O(log(N)+M)

返回值:

区间内的元素列表。

示例:


(6)ZRANGEBYSCORE(弃用)

返回分数在 min 和 max 之间的元素,默认情况下,min 和 max 都是包含的,可以通过 '(' 排除。

备注:这个命令可能在 6.2.0 之后废弃,并且功能合并到 ZRANGE 中。

语法:

ZRANGEBYSCORE key min max [WITHSCORES]  

命令有效版本:

1.0.5 之后

时间复杂度:

O(log(N)+M)

返回值:

区间内的元素列表。

示例:


(7)ZPOPMAX

删除并返回分数最高的 count 个元素。

语法:

ZPOPMAX key [count]

命令有效版本:

5.0.0 之后

时间复杂度:

O(log(N) * M),N 是有序集合的元素个数,M 表示 count,要删除的元素个数。

既然是尾删,为什么不把最后一个元素的位置特殊标记一下,后续删除不久省却了查找过程,直接 O(1) 了吗?

这个是有可能的,但是目前 Redis 并没有这么做。事实上,Redis 的源码中针对有序集合确实是记录了尾部的特定位置,但是在实际删除的时候并没有用上这个特性,而是直接调用了一个 “通用的删除函数”(给定一个 member 的值,进行查找,找到位置之后再删除)。(个人认为此处是存在优化空间的)

返回值:

分数和元素列表。

示例:

如果存在多个元素分数相同(分数是主要因素,相同的情况下会按照 member 字符串的字典序来决定先后顺序),同时为最大值,那么 zpopmax 删除最大元素时,仍然只会删除其中一个元素。


(8)BZPOPMAX

ZPOPMAX 的阻塞版本。可以同时读多个有序集合。

语法:

BZPOPMAX key [key ...] timeout

timeout 单位是 s,支持小数形式。

命令有效版本:

5.0.0 之后

时间复杂度:

O(log(N)),删除最大值花费的时间。

如果当前 BZPOPMAX 同时监听多个 key,假设 key 是 M 个,那么此时时间复杂度是 O(log(N) * M) 吗?

每个这样的 key 上面都删除一次元素才需要 * M,而这里是从这若干个 key 中只删除一次。

返回值:

元素列表。

示例:


(9)ZPOPMIN

删除并返回分数最低的 count 个元素。

语法:

ZPOPMIN key [count] 

命令有效版本:

5.0.0 之后

时间复杂度:

O(log(N) * M)

返回值:

分数和元素列表。

示例:


(10)BZPOPMIN

ZPOPMIN 的阻塞版本。

语法:

BZPOPMIN key [key ...] timeout

命令有效版本:

5.0.0 之后

时间复杂度:

O(log(N))

返回值:

元素列表。

示例:


(11)ZRANK

返回指定元素的排名,升序。

语法:

ZRANK key member

命令有效版本:

2.0.0 之后

时间复杂度:

O(log(N))

ZRANK 查找元素的过程和 ZCOUNT 是一样的。

返回值:

排名。

示例:


(12)ZREVRANK

返回指定元素的排名,降序

语法:

ZREVRANK key member 

命令有效版本:

2.0.0 之后

时间复杂度:

O(log(N))

返回值:

排名。

示例:


(13)ZSCORE

返回指定元素的分数。

语法:

ZSCORE key member 

命令有效版本:

1.2.0 之后

时间复杂度:

O(1)

此处相当于 Redis 对于这样的查询操作做了特殊优化,付出了额外的空间代价。

返回值:

分数。

示例:


(14)ZREM

删除指定的元素。

语法:

ZREM key member [member ...] 

命令有效版本:

1.2.0 之后

时间复杂度:

O(M*log(N))

返回值:

本次操作删除的元素个数。

示例:


(15)ZREMRANGEBYRANK

按照排序,升序删除指定范围的元素,左闭右闭。

语法:

ZREMRANGEBYRANK key start stop  

命令有效版本:

2.0.0 之后

时间复杂度:

O(log(N)+M)

返回值:

本次操作删除的元素个数。

示例:


(16)ZREMRANGEBYSCORE

按照分数删除指定范围的元素,左闭右闭,也可以使用 '(' 来排除边界值。

语法:

ZREMRANGEBYSCORE key min max 

命令有效版本:

1.2.0 之后

时间复杂度:

O(log(N)+M)

返回值:

本次操作删除的元素个数。

示例:


(17) ZINCRBY

为指定的元素的关联分数添加指定的分数值。

语法:

ZINCRBY key increment member

命令有效版本:

1.2.0 之后

时间复杂度:

O(log(N))

返回值:

增加后元素的分数。

示例:

ZINCRBY 不光会修改分数内容,也能同时移动元素位置,保证整个有序集合仍然是升序的。


2、集合间操作

有序集合的交集操作:


(1)ZINTERSTORE

求出给定有序集合中元素的交集并保存进目标有序集合中,在合并过程中以元素为单位进行合并,元素对应的分数按照不同的聚合方式和权重得到新的分数。

在有序集合中,member 是元素的本体,score 只是辅助排序的工具人。因此,在进行比较 “相同” 时,只要 member 相同即可。如果 member 相同,score 不同,进行交集合并之后的最终分数看 AGGREGATE 后面的属性。

语法:

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE <SUM | MIN | MAX>]
numkeys 是一个整数,用来描述后续有几个 key 参与交集运算。

命令有效版本:

2.0.0 之后

时间复杂度:

O(N*K)+O(M*log(M)),N 是输入的有序集合中,最小的有序集合的元素个数;K 是输入了几个有序集合;M 是最终结果的有序集合的元素个数。

返回值:

目标集合中的元素个数。

示例:


有序集合的并集操作:


(2)ZUNIONSTORE

求出给定有序集合中元素的并集并保存进目标有序集合中,在合并过程中以元素为单位进行合并,元素对应的分数按照不同的聚合方式和权重得到新的分数。

语法:

ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE <SUM | MIN | MAX>]

命令有效版本:

2.0.0 之后

时间复杂度:

O(N)+O(M*log(M)) N 是输入的有序集合总的元素个数,M 是最终结果的有序集合的元素个数。

返回值:

目标集合中的元素个数

示例:


3、命令小结

有序集合命令:


4、内部编码

有序集合类型的内部编码有两种:

  • ziplist(压缩列表):当有序集合的元素个数小于 zset-max-ziplist-entries 配置(默认 128 个),同时每个元素的值都小于 zset-max-ziplist-value 配置(默认 64 字节)时,Redis 会用 ziplist 来作为有序集合的内部实现,ziplist 可以有效减少内存的使用。
  • skiplist(跳表):当 ziplist 条件不满足时,有序集合会使用 skiplist 作为内部实现,因为此时 ziplist 的操作效率会下降。

简单来说,跳表是一个 “复杂链表”,查询元素的时间复杂度是 O(logN)。相比于树形结构,更适合按照范围获取元素。

(1)当元素个数较少且每个元素较小时,内部编码为 ziplist

(2)当元素个数超过 128 个,内部编码 skiplist

(3)当某个元素大于 64 字节时,内部编码 skiplist


5、使用场景

有序集合比较典型的使用场景就是排行榜系统。例如常见的网站上的热榜信息,榜单的维度可能是多方面的:按照时间、按照阅读量、按照点赞量。本例中我们使用点赞数这个维度,维护每天的热榜:

(1)添加用户赞数

例如用户 james 发布了一篇文章,并获得 3 个赞,可以使用有序集合的 zadd 和 zincrby 功能:

zadd user:ranking:2022-03-15 3 james

之后如果再获得赞,可以使用 zincrby:

zincrby user:ranking:2022-03-15 1 james

(2)取消用户赞数

由于各种原因(例如用户注销、用户作弊等)需要将用户删除,此时需要将用户从榜单中删除掉,可以使用 zrem。例如删除成员 tom:

zrem user:ranking:2022-03-15 tom


(3)展示获取赞数最多的 10 个用户

此功能使用 zrevrange 命令实现:

zrevrangebyrank user:ranking:2022-03-15 0 9

(4)展示用户信息以及用户分数

次功能将用户名作为键后缀,将用户信息保存在哈希类型中,至于用户的分数和排名可以使用 zscore 和 zrank 来实现。

hgetall user:info:tom
zscore user:ranking:2022-03-15 mike
zrank user:ranking:2022-03-15 mike

三、渐进式遍历

Redis 使用 scan 命令进行渐进式遍历键,进而解决直接使用 keys 获取键时可能出现的阻塞问题。不是一个命令将所有的 key 都拿到,而是每执行一次命令,只获取到其中的一小部分,这样就可以保证当前这一次操作不会太卡。每次 scan 命令的时间复杂度是 O(1),但是要完整地完成所有键的遍历,需要执行多次 scan。渐进式遍历其实是一组命令,这一组命令的使用方法是一样的。整个过程如下图所示:

scan 命令渐进式遍历

  • 首次 scan 从 0 开始。
  • 当 scan 返回的下次位置为 0 时,遍历结束。

返回值的前半部分1)是告诉我们,下次继续遍历的光标(当作一个字符串即可)要从哪里开始。第二部分2)是我们真正遍历到的 key 的内容。


1、SCAN

以渐进式的方式进行键的遍历。

渐进式遍历再遍历过程中不会在服务器这边存储任何的状态信息,此处的遍历是随时可以终止的,不会对服务器产生任何的副作用。

语法:

SCAN cursor [MATCH pattern] [COUNT count] [TYPE type]

这里的 count 是限制这一次遍历能够获取到多少个元素,默认是 10。

注意:此处的 count(给 Redis 服务器一个 “提示” / “建议”,写入的 count 和实际返回的 key 的个数不一定完全相同,但是不会差很多)和 MySQL 的 limit(精确的)不一样。

命令有效版本:

2.8.0 之后

时间复杂度:

O(1)

返回值:

下一次 scan 的游标(cursor)以及本次得到的键。

示例:

除了 scan 以外,Redis 面向哈希类型、集合类型、有序集合类型分别提供了 hscan、sscan、zscan 命令,它们的用法和 scan 基本类似。

注意:渐进性遍历 scan 虽然解决了阻塞的问题,但如果在遍历期间键有所变化(增加、修改、删除),可能导致遍历时键的重复遍历或者遗漏。


四、数据库管理

Redis 提供了几个面向 Redis 数据库的操作,分别是命令:dbsize、select、flushdb、flushall。


1、切换数据库

select dbIndex  

许多关系型数据库,例如 MySQL 支持在一个实例下有多个数据库存在的,但是与关系型数据库用字符来区分不同数据库名不同,Redis 只是用数字作为多个数据库的实现。Redis 默认配置中是有 16 个数据库,我们不能创建新的数据库,也不能删除已有的数据库,这 16 个数据库中的数据是隔离的(相互之间不会有影响)。select 0 操作会切换到第⼀个数据库,select 15 会切换到最后⼀个数据库。

0 号数据库和 15 号数据库保存的数据是完全不冲突的,如下图所示,即各种有各自的键值对。默认情况下,我们处于数据库 0。

Redis 管理的数据库:

Redis 中虽然支持多数据库,但随着版本的升级,其实不是特别建议使用多数据库特性。如果真的需要完全隔离的两套键值对,更好的做法是维护多个 Redis 实例,而不是在一个 Redis 实例中维护多数据库。这是因为本身 Redis 并没有为多数据库提供太多的特性,其次无论是否有多个数据库,Redis 都是使用单线程模型,所以彼此之间还是需要排队等待命令的执行。同时多数据库还会让开发、调试和运维工作变得复杂。所以实践中,始终使用数据库 0 其实是⼀个很好的选择


2、清除数据库

flushdb / flushall 命令用于清除数据库,区别在于 flushdb 只清除当前数据库,flushall 会清楚所有数据库。

永远不要在线上环境执行清除数据的操作,除非你想体验一把 “从删库到跑路” 的操作。 

语法:

FLUSHDB [ASYNC | SYNC] 

FLUSHALL [ASYNC | SYNC] 

  • ASYNC:异步
  • SYNC:同步

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3280515.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Camera Raw:五阶段修图流程

在使用 Camera Raw 修图时&#xff0c;如果按照一定的流程来进行&#xff0c;可以大大提高工作效率。这里提出的五阶段修图流程&#xff0c;简单来说就是&#xff1a; 1、调亮度&#xff0c;定影调 2、还原校正修复 3、局部调整优化 4、调颜色&#xff0c;定色调 5、存储、输出…

【C语言】qsort详解——能给万物排序的神奇函数

&#x1f984;个人主页:小米里的大麦-CSDN博客 &#x1f38f;所属专栏:https://blog.csdn.net/huangcancan666/category_12718530.html ⚙️操作环境:Visual Studio 2022 目录 一、引言 二、qsort函数介绍 1.函数原型 2.参数说明 2.1比较函数 3.使用示例 3.1对一维数组进…

【Canvas与艺术】五色五角大楼

【成图】 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>五L莫比乌斯五角大楼</title><style type"text/css&qu…

芋道以开源之名行下作之事 恬不知耻 标榜自己开源 公开源码+sql 不用再加入知识星球

资源 链接: https://pan.baidu.com/s/1TeuxbAUfLQ5_BqMBF1kniQ?pwdcqud 提 取码: cqud 依次为后端、补充版的sql、前端 此文档内安装部署等一应俱全

科普文:深入理解ElasticSearch体系结构

概叙 Elasticsearch是什么&#xff1f; Elasticsearch&#xff08;简称ES&#xff09;是一个分布式、可扩展、实时的搜索与数据分析引擎。ES不仅仅只是全文搜索&#xff0c;还支持结构化搜索、数据分析、复杂的语言处理、地理位置和对象间关联关系等。 官网地址&#xff1a;…

MSA+抑郁症模型总结(一)(论文复现)

MSA抑郁症模型总结&#xff08;一&#xff09;&#xff08;论文复现&#xff09; 本文所涉及所有资源均在传知代码平台可获取 文章目录 MSA抑郁症模型总结&#xff08;一&#xff09;&#xff08;论文复现&#xff09;情感分析在多场景的应用一、概述二、论文地址三、研究背景四…

PyTorch 2.0中图像增强方法详解

【图书推荐】《PyTorch深度学习与计算机视觉实践》-CSDN博客 基于Vision Transformer的mini_ImageNet图片分类实战_imagenet数据集-CSDN博客 Vision Transformer模型是目前图形识别领域最为前沿的和性能最好的图形分类模型&#xff0c;它能够对目标图像做出准确度最高的判断。…

《动手做科研 》| 05. 如何开展和记录实验

地址链接:《动手做科研》05. 如何开展和记录实验 导读: 当我们开始训练多个具有不同超参数的模型&#xff0c;我们就需要对实验开始进行管理。我们将其分为三个部分&#xff1a;实验追踪、超参数搜索和配置设置。我们将使用 Weights & Biases 来演示实验记录和追踪&#xf…

支持AI的好用的编辑器aieditor

一、工具概述 AiEditor 是一个面向 AI 的下一代富文本编辑器&#xff0c;她基于 Web Component&#xff0c;因此支持 Layui、Vue、React、Angular 等几乎任何前端框架。她适配了 PC Web 端和手机端&#xff0c;并提供了 亮色 和 暗色 两个主题。除此之外&#xff0c;她还提供了…

【源码+文档+调试讲解】乡镇篮球队管理系统设计与实现

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本乡镇篮球队管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信…

基础篇| 全网最全详解12个大模型推理框架

01 什么是框架? 开始介绍之前, 我们先了解一下什么是框架?xx框架-IT人经常听到的名词。但是又有多少人知道框架的意思? 框架&#xff08;framework&#xff09;是一个框子:指其约束性&#xff0c;也是一个架子——指其支撑性。是一个基本概念上的结构&#xff0c;用于去解…

新作品,一个通用的 Cloudflare Workers HTTP 反向代理

本文介绍我最近写的新作品&#xff1a;使用 Cloudflare Workers/Pages 搭建 HTTP 反向代理&#xff0c;代码已经全部开源在 GitHub&#xff0c;按照 README 里面的脚本搭建就可以了&#xff0c;非常简单。 GitHub&#xff1a;https://github.com/jonssonyan/cf-workers-proxy …

数字图像处理 第三章 灰度变换和空间滤波(上)

文章目录 本章简介一、背景知识 P62 - P641.1 灰度变换和空间滤波基础 P62 - P63二、一些基本的灰度变换函数 P64 - P712.1 图像反转 P642.2 对数变换 P64 - P662.3 幂律(伽马变换 P66 - P682.4 分段线性变换函数 P68 - P71本章知识点总结本章简介 本章讨论在空间域中的图像增强…

【C/C++】关于 extern “C“ 的理解

详细解释 #ifdef __cplusplus extern "C" 在C中&#xff0c;#ifdef __cplusplus 和 extern "C" 是用于处理C和C混合编程中的名称修饰&#xff08;name mangling&#xff09;问题的预处理器指令和关键字。 #ifdef __cplusplus __cplusplus 是一个预处理器…

人工智能大模型发展带来的风险挑战和对策

经过近70年的发展&#xff0c;人工智能技术发展经历了三次起伏&#xff0c;2022年以来&#xff0c;以ChatGPT、Sora等为代表的预训练大模型持续取得突破&#xff0c;推动着人工智能技术从感知向认识&#xff0c;从分析判断式向生成式&#xff0c;从专用向通用进入快速发展的新阶…

PythonDjangoMysql外卖app系统32762-计算机毕业设计项目选题推荐(附源码)

摘 要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;餐饮外卖当然也不例外。 外卖app系统主要功能模块包括后台首页&#xff0c;轮播图&#xff0c;资源管理&#xff08;餐饮…

【CTFWP】ctfshow-web40

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 题目介绍&#xff1a;题目分析&#xff1a;payload&#xff1a;payload解释&#xff1a;payload2&#xff1a;payload2解释&#xff1a;flag 题目介绍&#xff1a; …

高等数学 第七讲 一元函数积分学的概念和性质_不定积分_定积分_变限积分_反常积分

1.不定积分 文章目录 1.不定积分1.1 原函数1.1.1 原函数与不定积分的定义1.1.2 原函数存在定理 2.定积分2.1 定积分的定义2.2 定积分的精确定义2.3 定积分的几何意义2.4 定积分的存在定理2.5 定积分的性质 3.变限积分3.1 变限积分的定理3.2 变限积分的性质 4.反常积分(待更新) …

红酒标签设计:艺术与品味的结合

在红酒的世界里&#xff0c;每一瓶酒都如同一位优雅的舞者&#xff0c;在酒柜的舞台上静静诉说着自己的故事。而红酒的标签&#xff0c;则是这位舞者身上较华丽的舞裙&#xff0c;它不仅是红酒的身份证明&#xff0c;更是艺术与品味的很好结合。今天&#xff0c;我们就来聊聊红…

重载云台摄像机如何通过国标28181接入到统一视频接入平台(视频国标接入平台)

目录 一、国标GB/T 28181介绍 1、国标GB/T28181 2、内容和特点 二、重载云台摄像机 1、定义 2、结构与设计 3、功能和优势 4、特点 5、应用场景 二、接入准备工作 1、确定网络环境 &#xff08;1&#xff09;公网接入 &#xff08;2&#xff09;专网传输 2、检查重…