찾다
데이터 베이스MySQL 튜토리얼四:redis的sets类型相关操作(有序和无序集合)

================四五种(有序和无序集合):sets类型(就是集合)============= 一介绍: set表示集合,添加是是随意添加的-----无序集合 set是集合,它是string类型的无序集合。 set是通过hash table实现的,添加,删除和查找的复杂度都是0(1)。 对集合我们

================四五种(有序和无序集合):sets类型(就是集合)=============
一介绍: set表示集合,添加是是随意添加的----->无序集合

set是集合,它是string类型的无序集合。
set是通过hash table实现的,添加,删除和查找的复杂度都是0(1)。
对集合我们可以取并集、交集、差集。
通过这写操作我们可以实现sns中的好友推荐和blog的tag功能

1:sadd
向名称key的set中添加元素(唯一的)
例:sadd myset1 one ---->向集合myset1中添加元素one
sadd myset1 two
查看:smembers myset1
2:srem
删除名称为key的set中的元素
例:sadd myset2 one
srem myset2 one --->删除one元素
3:spop
随机返回并删除名称为key的set中一的个元素
例:spop myset3 --->随机弹出删除的元素
4:sdiff
返回所有给定key与第一个key的差集
myset1=1,2 myset2=3,2 --返回1
例:sdiff myset1 myset2 ---->谁在前面以谁为标准
4:sdiffstore
返回所有给定key与第一个key的差集,并将结果保存在一个新的key中
例:sdiffstore myset4 myset2 myset3 ---->将myset2与myset3的差集弹出并保存到myset4中
5:sinter
返回所有给定key的交集(交集:里面相同的元素)
two,one three,one --->one
例:sinter myset2 myset3 --->之间的交集

6: sinterstore
返回所有给定key与第一个key的交集,并将结果保存在一个新的key中
例:sinterstore myset4 myset2 myset3 ---->将myset2与myset3的交集保存到myset4中
7:sunion
返回所有给定key的并集
例:sunion myset1 myset2 --->取并集
8:sunionstore
返回所有给定key的并集,并保存到新的key中
例:sunionstore myset4 myset1 myset2 --->取并集并 保存到myset4中
9:smove
从第一个key中对应的set中移除某个元素并添加到第二个对应的key中
例:smove myset2 myset7 three --->将myset2中的元素移动到myset7里面
10:scard
返回名称为key的set的元素个数
例:scard myset8 ---->返回元素个数
11:sismember
测试某个元素是否是名称为KEY的set中的元素
例:sismember myset2 two --->测试two是否是myset2中的元素
12:srandmember(无序的取)
随机返回名称为key的set的一个元素,但不删除元素
例:srandmember myset3 --->随机去除myset3的元素
13:

二介绍: sorted sets=========》有序集合

sortes set是set的一个升级版本,它在set的基础上增加了一个顺序属性,
这一属性在添加修改元素的时候可以指定,每次指定后,zset会自动重新按新的值调整顺序。
可以理解为有两列的MySQL表,一列存value,一列存顺序。操作中key理解为zset(有序集合的名称)的名字
1: zadd ---重复插入时候会不成功,且将顺序更新
向名称为key的zset中添加元素member,score用于排序,如果该元素存在,则更新其顺序
例:zadd myzset1 1 one ---> 插入了one并指定顺序号
zrange
取值:zrange myzset1 0 -1 -----> 取myzset1的所有元素
zrange myzset1 0 -1 withscores ---->取出元素并吧顺序号输出
2:zrem 删除有序集合中的一个元素
删除名称为key的zset中的元素member
例子:zrem zset1 two --->删除two元素
3:zincrby
如果在名称为key的zset中已经存在元素member,则改元素的score
增加increment(顺序号)否则向该集合中添加元素,其score的值为increment
例:zincrby ssett1 2 one ---->对顺序号减
zincrby ssett1 -2 one ---->对顺序号加
4:zrank
返回名称为key的zset中member元素的排名(按score从小到大排序)即下标
例:zrange zset2 0 -1 withscores
zrank zset2 four ---->返回一个元素的索引值
5:zrevrank
返回名称为key的zset中member元素的排名(按score从大到小排序)即下标
例:zrevrank zset2 four ---->和zrank顺序相反
6: zrevrange
值按降序排序(score从大到小排序)
例:zrevrange zset2 0 -1 withscoress
7:zrangebyscore
返回集合中score在给定区域的元素
例:zrangebyscore zset2 2 4 withscores --->取下标2,3,4,且有序返回
8:zcount
返回集合中score在给定区域的数量
例:zrangebyscore zset2 2 4 ----->2,3,4 ,就会返回3表示有3个元素
9:zcrad
返回集合元素中的个数
zcrad zset2 ---->zset2里面所有元素的个数
10:zremrangebyrank
删除集合中排名在给定区间的元素(按照索引删除)
例:zremrangebyrank zset2 1 1 ---->删除索引为 1到1的(1),2,3(删除2和3)
11:zremrangebyscore
删除集合中score给定区间的元素(按照顺序号删除)
例:zremrangebyscore zset2 2 5 --->删除顺序号为2到5

========================================END========================================
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL 문자열 유형 : 스토리지, 성능 및 모범 사례MySQL 문자열 유형 : 스토리지, 성능 및 모범 사례May 10, 2025 am 12:02 AM

mysqlStringTypESmpactStorageAndperformanceAsfollows : 1) charisfixed, adlaysamestoragespace.

MySQL 문자열 유형 이해 : Varchar, Text, Char 등MySQL 문자열 유형 이해 : Varchar, Text, Char 등May 10, 2025 am 12:02 AM

mysqlstringtypesincludevarchar, text, char, enum, and set.1) varcharisversatileforvariable-lengthstringsupciedlimit.2) textisidealforlargetextStorage whithoudfinedlength.3) charisfixed, witableforconsistentDatalikecodes.4)

MySQL의 문자열 데이터 유형은 무엇입니까?MySQL의 문자열 데이터 유형은 무엇입니까?May 10, 2025 am 12:01 AM

mysqloffersvariousstringdatatatypes : 1) charfixed-lengthstrings, 2) varcharforvariable-lengthtext, 3) binaryandvarbinaryforbinarydata, 4) blobandtextforlargedata 및 5) enumandsetforcontrolledInput.achtolledinput.CheachorciCificusessandperististicatististicatististics

새로운 MySQL 사용자에게 권한을 부여하는 방법새로운 MySQL 사용자에게 권한을 부여하는 방법May 09, 2025 am 12:16 AM

TograntpermissionSt

MySQL에서 사용자를 추가하는 방법 : 단계별 가이드MySQL에서 사용자를 추가하는 방법 : 단계별 가이드May 09, 2025 am 12:14 AM

ToadDuserSinMySqleFeffectially, 다음에 따르면, 다음 사항을 따르십시오

MySQL : 복잡한 권한이있는 새 사용자 추가MySQL : 복잡한 권한이있는 새 사용자 추가May 09, 2025 am 12:09 AM

toaddanewuser와 함께 complexpermissionsinmysql, followthesesteps : 1) createShereuser'NewUser '@'localhost'Identifiedby'pa ssword ';. 2) grantreadaccesstoalltablesin'mydatabase'withgrantselectonmydatabase.to'newuser'@'localhost';. 3) GrantWriteAccessto '

MySQL : 문자열 데이터 유형 및 콜라주MySQL : 문자열 데이터 유형 및 콜라주May 09, 2025 am 12:08 AM

MySQL의 문자열 데이터 유형에는 char, varchar, binary, varbinary, blob 및 텍스트가 포함됩니다. 콜라이트는 문자열의 비교와 분류를 결정합니다. 1. 차량은 고정 길이 스트링에 적합하고 Varchar는 가변 길이 스트링에 적합합니다. 2. 이진 및 바이너리는 이진 데이터에 사용되며 Blob 및 텍스트는 큰 객체 데이터에 사용됩니다. 3. UTF8MB4_UNICODE_CI와 같은 정렬 규칙은 상류 및 소문자를 무시하며 사용자 이름에 적합합니다. UTF8MB4_BIN은 사례에 민감하며 정확한 비교가 필요한 필드에 적합합니다.

MySQL : Varchars에는 몇 개의 길이를 사용해야합니까?MySQL : Varchars에는 몇 개의 길이를 사용해야합니까?May 09, 2025 am 12:06 AM

가장 좋은 mysqlvarchar 열 길이 선택은 데이터 분석을 기반으로하고, 향후 성장을 고려하고, 성능 영향을 평가하고, 문자 세트 요구 사항을 기반으로해야합니다. 1) 일반적인 길이를 결정하기 위해 데이터를 분석합니다. 2) 미래 확장 공간을 예약하십시오. 3) 성능에 대한 큰 길이의 영향에주의를 기울이십시오. 4) 문자 세트가 스토리지에 미치는 영향을 고려하십시오. 이러한 단계를 통해 데이터베이스의 효율성과 확장 성을 최적화 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음