>  기사  >  백엔드 개발  >  AWS Go SDK를 사용하여 DynamoDB에서 단일 필드만 업데이트하는 방법

AWS Go SDK를 사용하여 DynamoDB에서 단일 필드만 업데이트하는 방법

WBOY
WBOY앞으로
2024-02-05 23:51:12454검색

如何使用 AWS Go SDK 仅更新 DynamoDB 中的单个字段

질문 내용

제가 어려움을 겪고 있는 이 문제에 대해 누군가가 밝힐 수 있기를 바랍니다.

다이나모에 이 테이블이 있으니 이름을 부르자 people ,在这个表中,我有 id 的属性作为我们的分区键、namelastnamestatus . 단일 속성만 업데이트하거나 ID의 모든 속성을 저장할 수 있기를 원합니다. 이제 이것이 제가 하는 방법입니다. 나는 다음과 같은 구조를 만들었습니다:

으아악

서버의 요청은 단순히 그 사람의 성을 업데이트하므로 요청 본문은 다음과 같습니다.

으아악

요청을 구조에 바인딩한 후 Dynamo로 전송될 객체는 다음과 같습니다.

으아악

이제 보시다시피 dynamo에 쓸 때가 되면 속성 하나만 업데이트해야 하고 나머지 빈/비어 있는 속성은 무시해야 합니다.

이를 위해 작성된 코드는 다음과 같이 요약될 수 있습니다.

으아악

이제 업데이트에는 문제가 없습니다. 문제는 해당 null 값을 건너뛰고 데이터가 있는 값만 업데이트할 수 있는 firstnamestatus 的 null 值也被传递。我尝试过阅读他们的文档,但还是有点困惑。我知道java sdk允许您传递一个名为update_skip_null_attributes 플래그입니다. go에 해당하는 것이 무엇인지 모르겠습니다. 도움이나 안내가 좋을 것입니다.

업데이트:

다음 모델을 사용해 보세요:

으아악

@jarmod 및 @fedonev의 조언을 따르세요. 논리적으로 그리고 문서를 사용하면 이것이 왜 작동해야 하는지 이해할 수 있지만 불행히도 작동하지 않습니다

SDK를 v1에서 v2로 전환하여 업데이트하면 도움이 되는지 확인하기로 결정했지만 다시 같은 곤경에 빠졌습니다. 이것이 내 업데이트 기능의 모습입니다.

으아악

저는 쿼리를 작성하고 업데이트하려는 ID로 json 페이로드를 거의 쿼리하고 쿼리해야 하는 항목의 차이를 기반으로 업데이트하는 함수를 생성하여 문제를 해결했습니다. 빈 필드는 쿼리됩니다. 결과 교체. 지금까지는 문제가 해결되었지만 의도한 기능으로 업데이트하는 방법은 여전히 ​​궁금합니다.


정답


@jarmod의 의견에 따르면 dynamodbav:",omitempty"마샬링 구조 태그를 적용할 때 값이 0인 필드를 건너뜁니다.

으아악

[편집: 사용법 추가] marshalmap 이제 레이블을 고려하여 0 값 필드가 무시됩니다. 맵을 반복하여 업데이트 표현식을 구성합니다.

으아악

op에 표시된 대로 표현식을 작성하고 해당 출력을 updateitem에 전달합니다.

위 내용은 AWS Go SDK를 사용하여 DynamoDB에서 단일 필드만 업데이트하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제