기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.
$substrBytes
Amazon DocumentDB의 $substrBytes 연산자는 지정된 바이트 범위를 기반으로 문자열에서 하위 문자열을 추출하는 데 사용됩니다. 이 연산자는 문자열에서 하위 문자열을 추출해야 할 때 유용하며 문자열의 각 문자를 나타내는 데 필요한 바이트 수가 중요합니다.
유니코드 코드 포인트 수에서 작동하는와 달리 $substrCP는 문자열의 문자를 나타내는 데 필요한 바이트 수에서 $substrBytes 작동합니다. 비 ASCII 문자가 포함된 문자열을 사용할 때 특히 유용할 수 있습니다. 이러한 문자를 나타내려면 1바이트 이상이 필요할 수 있기 때문입니다.
*참고:*$substr는 버전 3.4 이후 더 이상 사용되지 않습니다. $substr는 이제의 별칭입니다$substrBytes.
파라미터
-
string: 하위 문자열을 추출할 입력 문자열입니다. -
startByte: 추출할 하위 문자열의 0 기반 시작 바이트 위치입니다. 음수 값을 사용하여 문자열 끝에서 위치를 지정할 수 있습니다. -
length: 추출할 하위 문자열의 바이트 수입니다.
예제(MongoDB 쉘)
이 예제에서는 $substrBytes를 사용하여 비 ASCII 문자가 포함된 문자열에서 하위 문자열을 추출합니다.
샘플 문서 생성
db.people.insertMany([ { "_id": 1, "Desk": "Düsseldorf-NRW-021" }, { "_id": 2, "Desk": "Bremerhaven-HBB-32a" }, { "_id": 3, "Desk": "Norderstedt-SHH-892.50" }, { "_id": 4, "Desk": "Brandenburg-BBB-78" } ]);
쿼리 예제
db.people.aggregate([ { $project: { "state": { $substrBytes: [ "$Desk", 12, 3] } } } ])
출력
{ "_id": 1, "state": "NRW" },
{ "_id": 2, "state": "HBB" },
{ "_id": 3, "state": "SHH" },
{ "_id": 4, "state": "BBB" }
이 예제에서는 Desk 필드의 12바이트부터 시작하여 3바이트 하위 문자열을 추출$substrBytes하는 데를 사용합니다. 이렇게 하면 문자열에 ASCII가 아닌 문자가 포함될 수 있더라도 2자 상태 약어를 추출할 수 있습니다.
코드 예제
$substrBytes 명령을 사용하기 위한 코드 예제를 보려면 사용하려는 언어의 탭을 선택합니다.