>  기사  >  백엔드 개발  >  Redis 튜토리얼(5): 데이터 유형 설정

Redis 튜토리얼(5): 데이터 유형 설정

黄舟
黄舟원래의
2016-12-28 14:41:241275검색

1. 개요:

Redis에서는 Set 유형을 List 유형과 마찬가지로 이 유형의 데이터 값을 추가, 삭제 또는 삭제할 수도 있습니다. 요소가 존재하는지 여부와 기타 작업을 확인합니다. 이러한 작업의 시간 복잡도는 O(1)입니다. 즉, 작업이 일정한 시간에 완료됩니다. 세트가 포함할 수 있는 최대 요소 수는 4294967295입니다.
Set 컬렉션에는 List 유형과 달리 중복 요소가 허용되지 않으며 이는 C++ 표준 라이브러리의 집합 컨테이너와 완전히 동일합니다. 즉, 동일한 요소를 여러 번 추가하면 해당 요소의 복사본 하나만 Set에 유지됩니다. List 유형과 비교하여 Set 유형은 매우 중요한 기능적 특징도 가지고 있습니다. 즉, 합집합, 교차점, 차이 등 여러 Set 간의 집계 계산 작업이 서버 측에서 완료됩니다. 이러한 작업은 서버 측에서 완료되므로 매우 효율적이며 많은 네트워크 IO 오버헤드를 절약합니다.

2. 관련 명령어 목록:

입니다. SINTERSTORE대상 키 [key ...] 시간 복잡도의 N은 모든 세트의 총 멤버 수를 나타냅니다. 이 명령은 다음의 합집합을 반환합니다. 매개변수 세트의 모든 키와 연관된 세트의 멤버 조합원 수를 반환합니다.

3. 명령 예:

1. SADD/SMEMBERS/SCARD/SISMEMBER:

#在Shell命令行下启动Redis的客户端程序。
    /> redis-cli
    #插入测试数据,由于该键myset之前并不存在,因此参数中的三个成员都被正常插入。
    redis 127.0.0.1:6379> sadd myset a b c
    (integer) 3
    #由于参数中的a在myset中已经存在,因此本次操作仅仅插入了d和e两个新成员。
    redis 127.0.0.1:6379> sadd myset a d e
    (integer) 2
    #判断a是否已经存在,返回值为1表示存在。
    redis 127.0.0.1:6379> sismember myset a
    (integer) 1
    #判断f是否已经存在,返回值为0表示不存在。
    redis 127.0.0.1:6379> sismember myset f
    (integer) 0
    #通过smembers命令查看插入的结果,从结果可以,输出的顺序和插入顺序无关。
    redis 127.0.0.1:6379> smembers myset
    1) "c"
    2) "d"
    3) "a"
    4) "b"
    5) "e"
    #获取Set集合中元素的数量。
    redis 127.0.0.1:6379> scard myset
    (integer) 5

2. SPOP/SREM/SRANDMEMBER/SMOVE:

#删除该键,便于后面的测试。
    redis 127.0.0.1:6379> del myset
    (integer) 1
    #为后面的示例准备测试数据。
    redis 127.0.0.1:6379> sadd myset a b c d
    (integer) 4
    #查看Set中成员的位置。
    redis 127.0.0.1:6379> smembers myset
    1) "c"
    2) "d"
    3) "a"
    4) "b"
    #从结果可以看出,该命令确实是随机的返回了某一成员。
    redis 127.0.0.1:6379> srandmember myset
    "c"
    #Set中尾部的成员b被移出并返回,事实上b并不是之前插入的第一个或最后一个成员。
    redis 127.0.0.1:6379> spop myset
    "b"
    #查看移出后Set的成员信息。
    redis 127.0.0.1:6379> smembers myset
    1) "c"
    2) "d"
    3) "a"
    #从Set中移出a、d和f三个成员,其中f并不存在,因此只有a和d两个成员被移出,返回为2。
    redis 127.0.0.1:6379> srem myset a d f
    (integer) 2
    #查看移出后的输出结果。
    redis 127.0.0.1:6379> smembers myset
    1) "c"
    #为后面的smove命令准备数据。
    redis 127.0.0.1:6379> sadd myset a b
    (integer) 2
    redis 127.0.0.1:6379> sadd myset2 c d
    (integer) 2
    #将a从myset移到myset2,从结果可以看出移动成功。
    redis 127.0.0.1:6379> smove myset myset2 a
    (integer) 1
    #再次将a从myset移到myset2,由于此时a已经不是myset的成员了,因此移动失败并返回0。
    redis 127.0.0.1:6379> smove myset myset2 a
    (integer) 0
    #分别查看myset和myset2的成员,确认移动是否真的成功。
    redis 127.0.0.1:6379> smembers myset
    1) "b"
    redis 127.0.0.1:6379> smembers myset2
    1) "c"
    2) "d"
    3) "a"

3. SDIFF/SDIFFSTORE/SINTER/SINTERSTORE:

 #为后面的命令准备测试数据。
    redis 127.0.0.1:6379> sadd myset a b c d
    (integer) 4
    redis 127.0.0.1:6379> sadd myset2 c
    (integer) 1
    redis 127.0.0.1:6379> sadd myset3 a c e
    (integer) 3
    #myset和myset2相比,a、b和d三个成员是两者之间的差异成员。再用这个结果继续和myset3进行差异比较,b和d是myset3不存在的成员。
    redis 127.0.0.1:6379> sdiff myset myset2 myset3
    1) "d"
    2) "b"
    #将3个集合的差异成员存在在diffkey关联的Set中,并返回插入的成员数量。
    redis 127.0.0.1:6379> sdiffstore diffkey myset myset2 myset3
    (integer) 2
    #查看一下sdiffstore的操作结果。
    redis 127.0.0.1:6379> smembers diffkey
    1) "d"
    2) "b"
    #从之前准备的数据就可以看出,这三个Set的成员交集只有c。
    redis 127.0.0.1:6379> sinter myset myset2 myset3
    1) "c"
    #将3个集合中的交集成员存储到与interkey关联的Set中,并返回交集成员的数量。
    redis 127.0.0.1:6379> sinterstore interkey myset myset2 myset3
    (integer) 1
    #查看一下sinterstore的操作结果。
    redis 127.0.0.1:6379> smembers interkey
    1) "c"
    #获取3个集合中的成员的并集。    
    redis 127.0.0.1:6379> sunion myset myset2 myset3
    1) "b"
    2) "c"
    3) "d"
    4) "e"
    5) "a"
    #将3个集合中成员的并集存储到unionkey关联的set中,并返回并集成员的数量。
    redis 127.0.0.1:6379> sunionstore unionkey myset myset2 myset3
    (integer) 5
    #查看一下suiionstore的操作结果。
    redis 127.0.0.1:6379> smembers unionkey
    1) "b"
    2) "c"
    3) "d"
    4) "e"
    5) "a"

4. 적용 범위:


1) 사용할 수 있습니다. Redis Set 데이터 유형은 특정 블로그를 방문하는 고유 IP 주소 정보와 같은 일부 고유 데이터를 추적합니다. 이 시나리오에서는 블로그를 방문할 때마다 방문자의 IP를 Redis에 저장하기만 하면 되며 데이터 유형 설정은 자동으로 IP 주소의 고유성을 보장합니다.
2) 데이터 객체 간의 연관을 유지하는 데 사용할 수 있는 Set 유형의 서버측 집계 작업의 편리하고 효율적인 기능을 최대한 활용하세요. 예를 들어, 특정 전자제품을 구매한 모든 고객 ID는 특정 세트에 저장되고, 다른 전자제품을 구매한 고객 ID는 다른 세트에 저장됩니다. 이때 어떤 고객이 이를 동시에 구매했는지 알고 싶다면, 두 가지 상품이 있는 경우 세트의 교차 명령은 편리성과 효율성이라는 장점을 최대한 발휘할 수 있습니다.

위 내용은 Redis 튜토리얼(5)의 내용입니다: Set data type 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


명령 프로토타입 시간 복잡도 명령 설명 반환 값
SADDkey 멤버 [멤버 ...] O(N) 시간 복잡도의 N은 해당 작업의 멤버 수를 나타냅니다. 삽입 과정에서 사용하면 매개변수의 일부 멤버가 이미 Set에 존재하므로 해당 멤버는 무시되고 다른 멤버는 정상적으로 삽입됩니다. 이 명령을 실행하기 전에 키가 존재하지 않는 경우 이 명령은 새 세트를 생성한 다음 매개변수에 멤버를 하나씩 삽입합니다. 키 값이 Set 유형이 아닌 경우 이 명령은 관련 오류 정보를 반환합니다. 이 작업에 실제로 투입된 회원 수입니다.
SCARDkey O(1) Set의 멤버 수를 가져옵니다. 세트의 구성원 수를 반환합니다. 키가 존재하지 않으면 0을 반환합니다.
SISMEMBER 키 멤버 O(1) 매개변수에 지정된 멤버가 키와 연결된 Set 컬렉션에 이미 존재하는지 확인합니다. 1은 이미 존재함을 의미하고, 0은 존재하지 않거나 키 자체가 존재하지 않음을 의미합니다.
SMEMBERS 키 O(N) 시간 복잡도의 N은 세트에 이미 존재하는 멤버 수를 나타냅니다. 키와 연관된 세트의 모든 구성원을 가져옵니다. 세트의 모든 멤버를 반환합니다.
SPOPkey O(1) 세트의 구성원을 무작위로 제거하고 반환합니다. Set에 있는 요소의 레이아웃은 외부에서 제어되지 않으므로 List처럼 Set의 머리 부분이나 끝 부분에 어떤 요소가 있는지 확인하는 것은 불가능합니다. 제거된 멤버를 반환하거나, 키가 존재하지 않으면 nil을 반환합니다.
SREMkey 멤버 [member ...] O(N) 시간 복잡도의 N은 삭제된 멤버 수를 나타냅니다. 키와 연결된 세트에서 매개변수에 지정된 멤버를 삭제합니다. 존재하지 않는 매개변수 멤버는 무시됩니다. 키가 없으면 빈 세트로 처리됩니다. 세트에서 실제로 제거된 멤버 수 또는 없는 경우 0입니다.
SRANDMEMBER 키 O(1) SPOP과 동일하며 Set의 멤버를 무작위로 반환합니다. 차이점은 이 명령은 그렇지 않다는 것입니다. 복귀한 회원은 삭제됩니다. 임의의 위치에 있는 멤버를 반환하거나, 키가 없으면 nil을 반환합니다.
SMOVE소스 대상 멤버 O(1) 매개변수의 멤버를 소스 키에서 대상 키와 연결된 Set으로 원자적으로 이동합니다. 가운데. 따라서 특정 순간에 해당 멤버는 소스에 나타나거나 대상에 나타납니다. 멤버가 소스에 없으면 이 명령은 더 이상 작업을 수행하지 않고 0을 반환합니다. 그렇지 않으면 멤버가 소스에서 대상으로 이동됩니다. 현재 대상에 멤버가 이미 존재하는 경우 이 명령은 소스에서만 멤버를 제거합니다.Key와 연관된 Value가 Set이 아닌 경우 관련 오류 정보가 반환됩니다. 1은 정상적인 움직임을 의미하고, 0은 소스에 매개변수 멤버가 없음을 의미합니다
SDIFFkey [key ...] O(N) 시간 복잡도의 N은 모든 세트의 총 멤버 수를 나타냅니다. 매개변수의 첫 번째 키와 연관된 세트의 멤버와 모든 후속 키와 연관된 세트 간의 차이를 반환합니다. Key가 존재하지 않으면 빈 세트로 간주됩니다. 차이 결과 멤버 모음
SDIFFSTORE대상 키 [key ...] O(N 이 명령과 SDIFF 명령은 기능적으로 동일하며 둘 사이의 유일한 차이점은 SDIFF가 차이의 결과 멤버를 반환하는 반면, 이 명령은 대상 키와 연결된 Set에 차이 멤버를 저장한다는 것입니다. 이 작업은 해당 키를 덮어씁니다. 차이 멤버 수를 반환합니다.
SINTERkey [key ...] O(N*M) 시간. 복잡도의 N은 최소 세트의 요소 수를 나타내고, M은 매개변수의 세트 수를 나타냅니다. 따라서 이 명령은 매개변수의 모든 키와 연관된 세트의 멤버 교차를 반환합니다. 매개변수의 키와 연관된 집합이 비어 있거나 키가 존재하지 않으면 이 명령의 결과는 교집합 결과 멤버 집합
O(N*M) 이 명령은 기능적으로 SINTER 명령과 동일합니다. 둘 사이의 유일한 차이점은 SINTER가 SINTER의 결과 멤버를 반환한다는 것입니다. 이 명령은 대상과 관련된 Set에 저장된 교차점 멤버를 반환합니다. 대상 키가 이미 존재하는 경우 이 작업은 해당 멤버를 덮어씁니다. SUNION 키 [key] ...] O(N)
결합 결과 멤버 세트 SUNIONSTORE대상 키 [key ...] O(N) 이 명령은 기능적으로 SUNION 명령과 동일합니다. 둘 사이의 유일한 차이점은 SUNION이 공용체의 결과 멤버를 반환하는 반면, 이 명령은 대상 키와 연결된 Set에 공용체 멤버를 저장한다는 것입니다.
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.