일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- gcp cloud build
- 네트워크
- 백준
- Baekjoon
- nodejs
- gcp ci/cd
- sequelize
- 스프링 배치
- kotest
- 파이썬
- gcp
- Batch
- 회고
- 시스템 해킹
- node.js
- pwnable.xyz
- spring Batch
- programmers
- 사이버보안
- 웹해킹
- Python
- cloud run
- 프로그래머스
- 포너블
- hackctf
- 보안
- 리버싱
- 웹보안
- docker
- webhacking.kr
Archives
uju's Tech
[Node.js : Sequelize] Mysql 버전이 json타입을 지원하지 않을 때 본문
<본 포스팅은공부목적으로 작성되었습니다. 혹시 틀린 부분이 있거나 문제가 되는 부분이 있다면 답글 달아주세요!>
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를 처음 접했을 때는 이게 뭐지.. 라는 생각이 정말 많았는데 하면 할 수록 친숙해지고 있다..
'Node' 카테고리의 다른 글
어느날 발생한 [gyp: No Xcode or CLT version detected!] 에러 (0) | 2020.09.24 |
---|---|
[Node.js : Sequelize] many to one 관계 (0) | 2020.07.29 |
[Node.js : Sequelize] SQLITE_ERROR: Cannot add a UNIQUE column - 개발 회고 (0) | 2020.07.17 |
[Node.js/Sequelize] group by를 이용하여 상태별로 count 출력 - 개발 회고 (0) | 2020.07.16 |
[Node.js] json data 객체 안에 객체 배열 추가하기 (0) | 2020.07.06 |
Comments