

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

# \$1substrBytes
<a name="substrBytes"></a>

Amazon DocumentDB의 `$substrBytes` 연산자는 지정된 바이트 범위를 기반으로 문자열에서 하위 문자열을 추출하는 데 사용됩니다. 이 연산자는 문자열에서 하위 문자열을 추출해야 할 때 유용하며 문자열의 각 문자를 나타내는 데 필요한 바이트 수가 중요합니다.

유니코드 코드 포인트 수에서 작동하는와 달리 `$substrCP`는 문자열의 문자를 나타내는 데 필요한 바이트 수에서 `$substrBytes` 작동합니다. 비 ASCII 문자가 포함된 문자열을 사용할 때 특히 유용할 수 있습니다. 이러한 문자를 나타내려면 1바이트 이상이 필요할 수 있기 때문입니다.

\$1참고:\$1`$substr`는 버전 3.4 이후 더 이상 사용되지 않습니다. `$substr`는 이제의 별칭입니다`$substrBytes`.

**파라미터**
+ `string`: 하위 문자열을 추출할 입력 문자열입니다.
+ `startByte`: 추출할 하위 문자열의 0 기반 시작 바이트 위치입니다. 음수 값을 사용하여 문자열 끝에서 위치를 지정할 수 있습니다.
+ `length`: 추출할 하위 문자열의 바이트 수입니다.

## 예제(MongoDB 쉘)
<a name="substrBytes-examples"></a>

이 예제에서는 `$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자 상태 약어를 추출할 수 있습니다.

## 코드 예제
<a name="substrBytes-code"></a>

`$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()
```

------