uju's Tech

[Node.js : Sequelize] Mysql 버전이 json타입을 지원하지 않을 때 본문

Node

[Node.js : Sequelize] Mysql 버전이 json타입을 지원하지 않을 때

ujusy 2020. 7. 18. 14:45

<본 포스팅은공부목적으로 작성되었습니다. 혹시 틀린 부분이 있거나 문제가 되는 부분이 있다면 답글 달아주세요!>

 

table을 추가하고 칼럼을 추가하는 중 어떤 칼럼의 DataTyes를 json으로 지정해주어야 했다.

 

최신의 Mysql 버전은 DataTypes.json의 형태로 지원을 하고있다.

 

하지만 현재 개발하고 있는 Mysql 버전은 json 타입을 지원하지 않아 위와 같이 사용해 주지못한다.

 

그러면 어떻게 사용할 수 있을까?

 

model에서 getter와 setter을 이용해주면 된다.


1.DataType에는 JSON 대신 TEXT를 사용해주자.

2.getter와 setter을 만들어주자.

 

아래와 같이 구현을 해줄 수 있다.

 

value: {
      allowNull: true,
      type: DataTypes.TEXT,
      /**
       * @returns {null|any}
       */
      get() {
        try {
          return JSON.parse(this.getDataValue('value'));
        } catch (e) {
          return null;
        }
      },
      /**
       * @param {object} value
       */
      set(value) {
        if (!(value instanceof Object)) {
          throw Error('`value` should be an instance of Object');
        }
        this.setDataValue('value', JSON.stringify(value));
      },
    },
  },

 

이 내용은 stackOverflow에서와 기존 코드를 참고하였다. ㅎㅎ

 

처음에 Sequelize를 처음 접했을 때는 이게 뭐지.. 라는 생각이 정말 많았는데 하면 할 수록 친숙해지고 있다..

 

 

Comments