Redis의 문자열 데이터 유형 예 분석

WBOY
풀어 주다: 2023-06-03 10:47:49
앞으로
865명이 탐색했습니다.

개요:

문자열 유형은 Redis에서 가장 기본적인 데이터 저장 유형입니다. Redis에서는 이진 안전합니다. 즉, 이 유형은 JPEG 이미지 데이터나 Json 개체 설명 정보 등 모든 형식의 데이터를 받아들일 수 있습니다. . Redis에서 문자열 유형 값의 최대 용량은 512MB입니다.

관련 명령 목록:

SETBIT 지정된 오프셋에 BIT 값을 설정합니다. 값은 1 또는 0만 될 수 있습니다. 설정 후 명령은 원래 값을 반환합니다. 오프셋. 일부 BIT 값. 지정된 키가 존재하지 않는 경우 이 명령은 새 값을 생성하고 지정된 오프셋의 매개변수에 BIT 값을 설정합니다. Offset이 Value의 문자 길이보다 큰 경우 Redis는 Value를 확장하고 지정된 Offset의 매개 변수에 BIT 값을 설정하며 중간에 추가된 BIT 값은 0이 됩니다. 마지막으로 주의할 점은 오프셋 값이 0보다 커야 한다는 것입니다. GETBITO(1)MGETO(N)MSETO(N)MSETNXO(N)이 키 배치에 이미 키가 있으면 작업이 모두 롤백됩니다. 즉, 모든 수정 사항이 적용되지 않습니다. append key value 원래 값에 값을 추가합니다. 키가 존재하지 않으면 substr key start len ​​​​intercept를 추가하는 대신 새 키와 값을 만듭니다. 시작에서 키, len
명령 프로토타입 시간 복잡도 명령 설명 반환 값
APPEND O(1) If 키가 이미 존재하며 APPEND 명령은 매개변수 Value의 데이터를 기존 Value의 끝에 추가합니다. 키가 존재하지 않는 경우 APPEND 명령은 새 키/값을 생성합니다. 추가 후 값의 길이입니다.
DECR O(1)

은 지정된 키의 값을 1씩 원자적으로 감소시킵니다. Key가 존재하지 않는 경우 초기 값은 0이고 decr 이후의 값은 -1입니다. Value의 값이 Hello와 같은 정수 유형이 아닌 경우 작업은 실패

하고 해당 오류 메시지를 반환합니다. 참고: 이 연산의 값 범위는 64비트 부호 있는 정수입니다.

감소 후의 값입니다.
INCR O(1)

은 지정된 키의 값을 1씩 원자적으로 증가시킵니다. 키가 존재하지 않는 경우 초기 값은 0이고 증가 후 값은 1입니다. Value 값을 Hello 문자열과 같은 정수 값으로 변환할 수 없으면 작업이 실패하고

해당 오류 메시지가 반환됩니다. 참고: 이 연산의 값 범위는 64비트 부호 있는 정수입니다.

증가한 후의 값입니다.
DECRBY O(1)

은 지정된 키의 값을 원자적으로 감소시킵니다. decrby를 수행한 후 Key가 존재하지 않으면 초기값은 0이 되고 그 이후에는 -decrement가 된다. Value의 값을 Hello와 같은 정수 값(

)으로 변환할 수 없는 경우 작업이 실패하고 해당 오류 메시지가 반환됩니다. 참고: 이 연산의 값 범위는 64비트 부호 있는 정수입니다.

감소된 가치.
INCRBY O(1)

지정된 키의 값을 원자적으로 증가시킵니다. Key가 존재하지 않는 경우 초기값은 0이고 incrby 이후의 값은 증가됩니다. Value 값을 Hello

와 같이 정수 값으로 변환할 수 없는 경우 작업이 실패하고 해당 오류 메시지가 반환됩니다. 참고: 이 연산의 값 범위는 64비트 부호 있는 정수입니다.

가치 증가.
GET O(1) 지정된 키의 값을 가져옵니다. 키와 연결된 값이 문자열 유형이 아닌 경우 GET 명령은 문자열 값을 얻는 데만 사용할 수 있으므로 Redis는 오류 메시지를 반환합니다. 키와 관련된 값입니다. 키가 없으면 nil이 반환됩니다.
SET O(1) 지정된 문자열 값을 보유하도록 키를 설정합니다. 키가 이미 존재하는 경우 원래 값을 덮어씁니다. 항상 "OK"를 반환합니다.
GETSET O(1) 키를 지정된 값으로 원자적으로 설정하고 키의 원래 값을 반환합니다. GET 명령과 마찬가지로 이 명령은 문자열 값만 처리할 수 있습니다. 그렇지 않으면 Redis가 관련 오류 정보를 제공합니다. 키의 원래 값을 반환합니다. 키가 이전에 존재하지 않으면 nil이 반환됩니다.
STRLEN O(1) 지정된 Key의 문자 값 길이를 반환합니다. Value가 문자열 유형이 아닌 경우 Redis는 실행에 실패하고 관련 오류 정보를 제공합니다. 지정된 키의 값 문자 길이를 반환합니다. 키가 존재하지 않으면 0을 반환합니다.
SETEX O(1) 두 작업을 원자적으로 완료합니다. 하나는 Key 값을 지정된 문자열로 설정하는 동시에 Key in의 생존 시간(초)을 설정하는 것입니다. 레디스 서버. 이 명령어는 주로 Redis를 Cache 서버로 사용할 때 사용됩니다.
SETNX O(1) 지정된 Key가 존재하지 않는 경우 지정된 문자열 값을 보유하도록 Key를 설정합니다. 이때 그 효과는 SET 명령과 동일합니다. 반대로 키가 이미 존재하는 경우 명령은 아무 작업도 수행하지 않고 반환됩니다. 1은 설정이 성공했음을 의미하고, 그렇지 않으면 0을 의미합니다.
SETRANGE O(1)

지정된 키의 문자열 값 일부를 바꿉니다. 오프셋부터 시작하여 대체 길이는 명령의 세 번째 매개변수 값의 문자열 길이입니다. 오프셋 값이 키의 원래 값 문자열 길이보다 크면

Redis는 값( 오프셋 - 새 값을 추가하기 전의 strlen(value)) 양은 0x00입니다. 키가 존재하지 않는 경우 이 명령은 원래 값 길이가 0이라고 가정하고 새 값을 추가하기 전에 오프셋 문자

0x00을 추가합니다. 문자열 Value의 최대 길이가 512M인 경우 오프셋의 최대 값은 536870911입니다. 마지막으로 주의할 점은 이 명령이 실행될 때 지정된 키의 원래 값을 생성하는 경우 길이가 증가하면 Redis는 대체된 모든 문자열을 수용할 수 있을 만큼 충분한 메모리를 재할당하므로 성능이 어느 정도 영향을 받는다는 것입니다.

수정된 문자열 값 길이입니다.
GETRANGE O(1)

가로채낸 문자열의 길이가 매우 짧다면 이 명령의 시간 복잡도는 O(1)로 간주할 수 있고, 그렇지 않으면 O(N)입니다. 여기서 N은 가로채는 하위 문자열의 길이를 의미합니다. 이 명령이 하위 문자열을 가로채면 닫힌 간격의 시작(0은 첫 번째 문자를 나타냄)과 끝 문자가 모두 포함됩니다. 끝 값이 값의 문자 길이를 초과하는 경우 이 명령은 이후 모든 문자 데이터의 문자만 가로채게 됩니다. 시작.

하위 문자열
O(1)

지정된 오프셋에서 BIT의 원래 값입니다.

지정된 오프셋, 0 또는 1에서 BIT 값을 반환합니다. 이 명령은 Offset이 문자열 값의 길이를 초과하는 경우 0을 반환하므로 빈 문자열에 대해서는 항상 0을 반환합니다. 지정된 오프셋의 BIT 값입니다.
N은 획득한 키 수를 나타냅니다. 지정된 모든 키의 값을 반환합니다. 키 중 하나가 존재하지 않거나 해당 값이 문자열 유형이 아닌 경우 키 값은 nil을 반환합니다. 지정된 키 집합에 대한 값 목록을 반환합니다.
N은 지정된 키의 수를 나타냅니다. 이 명령은 매개변수의 모든 키/값 설정 작업을 원자적으로 완료합니다. 특정 동작은 SET 명령을 여러 번 반복적으로 실행하는 것으로 볼 수 있습니다. 이 명령은 실패하지 않으며 항상 OK를 반환합니다.
N은 지정된 키의 수를 나타냅니다. 이 명령은 매개변수의 모든 키/값 설정 작업을 원자적으로 완료합니다. 해당 동작은 SETNX 명령의 여러 반복 실행으로 볼 수 있습니다. 그러나 여기서 명확하게 언급해야 할 것은

String(문자열)

strlen 키 길이 가져오기

incr key 1

decr key 1

incrby key num 키 증가, num

decrby 키 num 키 감소 , 감소 num

getrange 키 시작 끝은 문자 키 [start, end]를 가로채고 헤더에는 꼬리도 포함됩니다.

setrange 키 오프셋 값은 오프셋 위치의 데이터를 값으로 바꿉니다(오프셋은 키의 인덱스입니다)

setex 키 초 값은 키의 만료 시간을 설정합니다.

키가 없으면 setnx 명령을 실행하면 키와 값이 설정되지만 키가 이미 있으면 setnx 명령이 실패하고 값을 추가할 수 없습니다. again

mset key1 value key2 value는 여러 키와 값을 한 번에 설정합니다

mget key1 key2 여러 키의 값을 한 번에 가져옵니다

msetnx key1 value key2 value 여러 키와 값을 한 번에 설정합니다. 키 중 하나가 있으면 모든 생성이 실패합니다.(원자성)

getset 키 값이 없으면 nil을 가져온 다음 값을 설정합니다. 이전에 얻은 값을 참조하는 경우 후속 값을 설정합니다(업데이트 작업). )

###############################################
127.0.0.1:6379> set key1 v
OK
127.0.0.1:6379> get key1
"v"
127.0.0.1:6379> keys *
1) "key1"
127.0.0.1:6379> exists key1
(integer) 1
127.0.0.1:6379> append key1 v1
(integer) 3
127.0.0.1:6379> get key1
"vv1"
127.0.0.1:6379> substr key1 0 3
"vv1"
127.0.0.1:6379> strlen key1
(integer) 3
127.0.0.1:6379> append key1 "hello1"
(integer) 9
127.0.0.1:6379> substr key1 1 2
"v1"
127.0.0.1:6379> substr key1 1 1
"v"
127.0.0.1:6379> append key2 "lisi"
(integer) 4
127.0.0.1:6379> get key2
"lisi"
###############################################
127.0.0.1:6379> set views 0
OK
127.0.0.1:6379> get views
"0"
127.0.0.1:6379> incr views
(integer) 1
127.0.0.1:6379> incr views
(integer) 2
127.0.0.1:6379> get views
"2"
127.0.0.1:6379> decr views
(integer) 1
127.0.0.1:6379> decr views
(integer) 0
127.0.0.1:6379> incrby views 10
(integer) 10
127.0.0.1:6379> decrby views 5
(integer) 5
####################################
127.0.0.1:6379> set key1 "hello,world"
OK
127.0.0.1:6379> GETRANGE key1 0 3
"hell"
127.0.0.1:6379> GETRANGE key1 0 -1
"hello,world"
127.0.0.1:6379> SETRANGE key2 3 2
(integer) 7
127.0.0.1:6379> get key2
"abc2efg"
########################################
127.0.0.1:6379> setex key3 30 hello
OK
127.0.0.1:6379> get key3
"hello"
127.0.0.1:6379> ttl key3
(integer) 24
127.0.0.1:6379> SETNX mykey redis
(integer) 1
127.0.0.1:6379> keys *
1) "mykey"
2) "key2"
3) "key1"
127.0.0.1:6379> SETNX mykey "MongoDB"
(integer) 0
127.0.0.1:6379> get mykey
"redis"
####################################
127.0.0.1:6379> mset k1 v1 k2 v2
OK
127.0.0.1:6379> mget k1 k2
1) "v1"
2) "v2"
127.0.0.1:6379> MSETNX k1 v1 k3 v3
(integer) 0
# 对象
# 这里的key是一个巧妙的设计 user:{id}:{filed} 
127.0.0.1:6379> msetnx user:1:name "zhangsan" user:1:age 2
(integer) 1
127.0.0.1:6379> mget user:1:name user:1:age
1) "zhangsan"
2) "2"
127.0.0.1:6379> set article:101:views 0
OK
127.0.0.1:6379> incr article:101:views
(integer) 1
127.0.0.1:6379> get article:101:views
"1"
###########################################################
127.0.0.1:6379> getset db redis
(nil)
127.0.0.1:6379> get db
"redis"
127.0.0.1:6379> getset db 10
"redis"
로그인 후 복사

String 비슷한 시나리오: 값은 문자열 외에 숫자일 수도 있습니다!

Counter

여러 장치 수 계산 uid:1923:follow 0
  • 팬 수
  • 객체 캐시 저장 공간

위 내용은 Redis의 문자열 데이터 유형 예 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:yisu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿