문자열 유형은 Redis에서 가장 기본적인 데이터 저장 유형입니다. Redis에서는 이진 안전합니다. 즉, 이 유형은 JPEG 이미지 데이터나 Json 개체 설명 정보 등 모든 형식의 데이터를 받아들일 수 있습니다. . Redis에서 문자열 유형 값의 최대 용량은 512MB입니다.
명령 프로토타입 | 시간 복잡도 | 명령 설명 | 반환 값 |
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 값을 설정합니다. 값은 1 또는 0만 될 수 있습니다. 설정 후 명령은 원래 값을 반환합니다. 오프셋. 일부 BIT 값. 지정된 키가 존재하지 않는 경우 이 명령은 새 값을 생성하고 지정된 오프셋의 매개변수에 BIT 값을 설정합니다. Offset이 Value의 문자 길이보다 큰 경우 Redis는 Value를 확장하고 지정된 Offset의 매개 변수에 BIT 값을 설정하며 중간에 추가된 BIT 값은 0이 됩니다. 마지막으로 주의할 점은 오프셋 값이 0보다 커야 한다는 것입니다. | 지정된 오프셋에서 BIT의 원래 값입니다. | GETBIT|
지정된 오프셋, 0 또는 1에서 BIT 값을 반환합니다. 이 명령은 Offset이 문자열 값의 길이를 초과하는 경우 0을 반환하므로 빈 문자열에 대해서는 항상 0을 반환합니다. 지정된 오프셋의 BIT 값입니다. | MGET | ||
N은 획득한 키 수를 나타냅니다. 지정된 모든 키의 값을 반환합니다. 키 중 하나가 존재하지 않거나 해당 값이 문자열 유형이 아닌 경우 키 값은 nil을 반환합니다. 지정된 키 집합에 대한 값 목록을 반환합니다. | MSET | ||
N은 지정된 키의 수를 나타냅니다. 이 명령은 매개변수의 모든 키/값 설정 작업을 원자적으로 완료합니다. 특정 동작은 SET 명령을 여러 번 반복적으로 실행하는 것으로 볼 수 있습니다. 이 명령은 실패하지 않으며 항상 OK를 반환합니다. | MSETNX | ||
N은 지정된 키의 수를 나타냅니다. 이 명령은 매개변수의 모든 키/값 설정 작업을 원자적으로 완료합니다. 해당 동작은 SETNX 명령의 여러 반복 실행으로 볼 수 있습니다. 그러나 여기서 명확하게 언급해야 할 것은 | 이 키 배치에 이미 키가 있으면 작업이 모두 롤백됩니다. 즉, 모든 수정 사항이 적용되지 않습니다.String(문자열) | append key value 원래 값에 값을 추가합니다. 키가 존재하지 않으면
incr key 1
decr key 1
incrby key num 키 증가, num
decrby 키 num 키 감소 , 감소 num
getrange 키 시작 끝은 문자 키 [start, end]를 가로채고 헤더에는 꼬리도 포함됩니다.
setrange 키 오프셋 값은 오프셋 위치의 데이터를 값으로 바꿉니다(오프셋은 키의 인덱스입니다)
setex 키 초 값은 키의 만료 시간을 설정합니다.
키가 없으면 setnx 명령을 실행하면 키와 값이 설정되지만 키가 이미 있으면 setnx 명령이 실패하고 값을 추가할 수 없습니다. againmset 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!