[DB] Json을 RDBMS(MySQL, PostgreSQL)에 저장해도 좋을까?
우선 키 밸류 형태의 값을 저장하기 위한 대표적인 저장소는 NoSQL입니다.
하지만 어떠한 데이터를 저장하느냐에 따라 MySQL을 이용해도 무방한 경우가 있는데 여러 사이트를 참고한 결과를 정리해보겠습니다.
아래의 조건을 다 통과한다면 RDBMS에서 사용해도 무방합니다.
RDBMS에 저장하기 위한 조건
1. 자주 업데이트 할 경우 성능에 영향을 끼친다.
예를 들어, 간단한 구조의 단순한 설정 데이터나 로그 데이터를 저장하는 경우, MySQL의 JSON 컬럼으로 충분할 수 있습니다.
2. 수정 과정이 일반 SQL보다 복잡하다.
3. 몽고 DB에 비해 집계 등 JSON에 대한 다양한 쿼리를 사용하기 어렵다.
4. 저장되는 Json이 크다면 속도 저하가 발생한다. (참고)
얼추 수천글자를 저장하는 케이스가 빈번하게 생긴다면 그 자체로 성능 저하가 발생한다.
상대적으로 같은 Json의 크기여도 MongoDB는 BSON 형태로 2진 코드로 삽입해서 용량이 적다.
5. 저장하는 데이터 자체가 MongoDB보다 용량이 크다(BSON is a binary-encoded serialization format that is more compact than raw JSON)
6. 기존 시스템이 RDBNS인 경우 고려할 수 있다. 오히려 데이터베이스를 하나 더 늘리는 것은 트랜잭션을 일관성있게 보장하는 것이 어렵고 마이그레이션 작업도 더 까다로워진다.
결론
MySQL이나 PostgreSQL나 다른 SQL 데이터베이스에서 적당한 크기의 JSON을 저장하고 검색하는 것에는 전혀 문제가 없습니다.
위 조건에 하나라도 부합하지 않는다면 NoSQL을 검토해볼 수 있겠습니다.