반응형

 

DynodbDB partiQL

NoSQL은 처음이라 

사실 등록, 조회, 수정, 삭제 모두 처음이다.

 

DynamoDB는 기본 키를 사용하여 테이블의 각 항목을 고유하게 식별하므로 등록 시 주의 점은 

기본키만 중복 안되게 하면 됐었다.

 

업데이트 쿼리를 진행하다 보니 하다 보니 아래 문구가 나왔다.

Where clause does not contain a mandatory equality on all key attributes

RDBMS에선 가능한 업데이트가 안된다.

where절엔 구분이 가능한 키 값이 들어가야 된다고 한다.

 

업데이트 후엔 리턴 값 설정이 있다.

  • ALL OLD * - 업데이트 작업 전에 표시된 항목 속성을 모두 반환합니다.
  • MODIFIED OLD * - 업데이트 작업 전에 표시된 업데이트된 속성만 반환합니다.
  • ALL NEW * - 업데이트 작업 후에 표시되는 항목 속성을 모두 반환합니다.
  • MODIFIED NEW * - UpdateItem 작업 후에 표시되는 업데이트된 속성만 반환합니다.

일단은 ALL NEW *  설정으로 사용해보기로 했다.

 

MODIFIED OLD  옵션은 업데이트된 내용을 속성만 반환된다고 했는데, 

실제 변경된 건지 안된 건지 중요해 보이지 않는다. 기존 값과 업데이트 값이 같아도 값이 리턴된다.

기존 값과 업데이트 값이 같든 다르든 해당 업데이트되는 속성은 무조건 업데이트되는 거 같다.

 

업데이트 문에

각 항목마다 SET을 추가해주고, 각 항목이 배열 형식이 있어서 다음과 같은 옵션이 있다.

  • LIST_APPEND: 목록 형식에 값을 추가합니다.
  • SET_ADD: 숫자 또는 문자열 집합에 값을 추가합니다.
  • SET_DELETE: 숫자 또는 문자열 집합에서 값을 제거합니다.

 

 

반응형
반응형

 

javascript로 dynamoDB 연동중

조회 후 리턴 정보가 object로 되어 있길래 

찾아보니 unmarshall 하는 게 있었다.

 

https://docs.aws.amazon.com/ko_kr/amazondynamodb/latest/developerguide/Introduction.html

 

What is Amazon DynamoDB? - Amazon DynamoDB

이 페이지에 작업이 필요하다는 점을 알려 주셔서 감사합니다. 실망시켜 드려 죄송합니다. 잠깐 시간을 내어 설명서를 향상시킬 수 있는 방법에 대해 말씀해 주십시오.

docs.aws.amazon.com

공식문서엔 관련 내용이 없다. 

 

마샬링이란 한 객체의 메모리에서의 표현방식을 저장 또한 전송에 적합한 다른 데이터 형식으로 변환하는 과정이다.

DynamoDB에서 전송에 적합에 데이터 형식으로 변환해서 보내준다고 이해하면 되겠다.

조회 결과의 데이터는 object로 사용하려면 언마샬링이 필요하다.

 

https://hwanine.github.io/network/Marshalling/

 

import  { unmarshall } from '@aws-sdk/util-dynamodb';

// marshall된 오프젝트를 unmarshall 함수를 통해 변환해서 사용해야 한다.
const dataRow = unmarshall(data.Items[0]);

 

 

공통 조회에서 결과 리턴전에 처리하는 것도 고려해볼 만하다.

 

const send = async (queryParams) => {
  try {
    const data = await ddbDocClient.send(new ExecuteStatementCommand(queryParams));
    // console.log(data.Items[0]);
    // return unmarshall(data.Items);
    return {Items : data.Items.map(item => unmarshall(item)) };
    // return data
  } catch (err) {
    return {
      message: err.message,
      httpStatusCode: err.$metadata.httpStatusCode
    };
  }
};

 

 

참고

https://www.tabnine.com/code/javascript/functions/marshall

반응형
반응형

DynomoDB local

dynamoDB 도커로 검색하면 아래 링크로 안내한다.

https://hub.docker.com/r/amazon/dynamodb-local

 

Docker Hub

 

hub.docker.com

 

Simply run docker run -p 8000:8000 amazon/dynamodb-local to execute DynamoDB locally.

 

저걸 믿고 실행한 후  aws-sdk를 이용하여 접속 테스트를 했는데,테이블 목록이 조회도가 안되는 것이다.

 

AWS NoSQL Workbanch로는 접속이 되고 조회가 되는데도 안됐다.

하루 온종일 찾아봤다.

 

docker run -p 8000:8000 amazon/dynamodb-local -jar DynamoDBLocal.jar -inMemory -sharedDb

-inMemory는 필요 없다.

inMemory는 옵션은 도커 껐다 켜면 데이터가 없어지는 거 같다.

 

중요한 건 -sharedDB 요거다.

저거 한 줄 때문에. 2일 정도 고생. 

반응형

+ Recent posts