$substrBytes - Amazon DocumentDB

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

$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 명령을 사용하기 위한 코드 예제를 보려면 사용하려는 언어의 탭을 선택합니다.

Node.js
const { MongoClient } = require('mongodb'); async function example() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const people = db.collection('people'); const result = await people.aggregate([ { $project: { "state": { $substrBytes: ["$Desk", 12, 3] } } } ]).toArray(); console.log(result); client.close(); } example();
Python
from pymongo import MongoClient def example(): client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client.test people = db.people result = list(people.aggregate([ { '$project': { "state": { '$substrBytes': ["$Desk", 12, 3] } } } ])) print(result) client.close() example()