MySQL [Mysql] mysql에서 json 다루기

2022.08.02 11:16

졸리운_곰 조회 수:52

[Mysql] mysql에서 json 다루기

0. 들어가기

-. 카드 실적에 대한 비정형 데이터 처리를 하다보니.. 만만한게 json이더라.

-. mysql에 json column 만들어 놓고 데이터 넣고빼고 해보자.

1. mysql 테이블 생성

-. 테이블부터 차근차근

CREATE SCHEMA `testschema`;

CREATE TABLE `testschema`.`jsontable` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(45) NULL,
  `jsoncol` JSON NULL,
  PRIMARY KEY (`id`));

 

 

 

0. 들어가기

-. 카드 실적에 대한 비정형 데이터 처리를 하다보니.. 만만한게 json이더라.

-. mysql에 json column 만들어 놓고 데이터 넣고빼고 해보자.

1. mysql 테이블 생성

-. 테이블부터 차근차근

CREATE SCHEMA `testschema`;

CREATE TABLE `testschema`.`jsontable` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(45) NULL,
  `jsoncol` JSON NULL,
  PRIMARY KEY (`id`));

 

 

 

 

2. json 입력

1) 가장 기본적으로, sql 쿼리 쓰듯이, string 입력을 할 수 있다.

INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_string", '{"a": "A", "b":"B"}');

2) json_object 형식으로 key, value 순서쌍으로도 입력 가능함.

INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object", json_object("a", "A", "b", "B"));

 

 

3) error) json 내 항목을 배열 (list)로 입력할 땐 바로 할 수 없다.

INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object with list", json_object("a", "[1,2,3]", "b", "B"));

4) json_array 형식을 사용해야함.

INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object with json_array", json_object("a", JSON_ARRAY(1,2,3), "b", "B"));

5) 정리하자면 이렇게

INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_string", '{"a": "A", "b":"B"}');
INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object", json_object("a", "A", "b", "B"));
INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object with list", json_object("a", "[1,2,3]", "b", "B"));
INSERT INTO `testschema`.`jsontable`(`name`, `jsoncol`) VALUES ("json_object with json_array", json_object("a", JSON_ARRAY(1,2,3), "b", "B"));

 

 

 

3. json 데이터 읽기

1) 일반적인 쿼리 구문으로 불러오기

select id, name, jsoncol FROM testschema.jsontable;

 

 

 

 

2) 특정 키값만 불러오기

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

select id, name, json_extract(jsoncol, '$.a') FROM testschema.jsontable;

 

 

3) json return 값에 따옴표(") 없애기

-. 위를 보면 따옴표가 중복으로 ('"A"') 형태로 나온다. json_unquote 구문을 추가해주면 이를 해결 가능함.

select id, name, JSON_UNQUOTE(JSON_EXTRACT(jsoncol, '$.a')) FROM testschema.jsontable;

 

 

4) 조건식 (WHERE) 사용

select id, name, json_extract(jsoncol, '$.a') FROM testschema.jsontable WHERE json_extract(jsoncol, '$.a') = "A";

 

4. json 데이터 변경

-. json_replace 사용법

1) json data의 'a' key 데이터 를 전부 'B' 로 바꿔서 불러옴

※ DB의 원본 데이터는 변하지 않음

select id, name, JSON_REPLACE(jsoncol, '$.a', "B") FROM testschema.jsontable;

 

원본
치환해서 출력: 'a' 가 전부 "B"

 

2) json 데이터 수정

-. UPDATE 테이블명 SET 컬럼명 = new 데이터

UPDATE testschema.jsontable SET jsoncol = JSON_REPLACE(jsoncol, '$.a', "B") WHERE id = 20;

 

 

 

5. 기타

1) json depth

SELECT JSON_DEPTH(jsoncol) FROM testschema.jsontable;

 

 

2) json keys

-. 들어있는 키를 반환 (depth 1만)

SELECT JSON_KEYS(jsoncol) FROM testschema.jsontable;

 

 

 

3) json path

-. 특정 키의 유무 확인 (마찬가지로 depth 1만되더라)

SELECT JSON_CONTAINS_PATH(jsoncol, 'all', '$.a') FROM testschema.jsontable;

 

[출처] https://givemethesocks.tistory.com/75

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25084
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24563
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25942
1002 [국가기술자격 빅데이터분석기사]빅데이터 분석기사 요약 - 3과목. 빅데이터 모델링 file 졸리운_곰 2022.09.19 41
1001 [국가기술자격 빅데이터분석기사]빅데이터 분석기사 요약 - 2과목. 빅데이터 탐색 file 졸리운_곰 2022.09.19 24
1000 [국가기술자격 빅데이터분석기사]빅데이터 분석기사 요약 - 1과목. 빅데이터 분석 기획 졸리운_곰 2022.09.19 50
999 [국가기술자격 빅데이터분석기사] [빅데이터분석기사 필기 요약] I.빅데이터 분석 기획 - 02. 데이터 분석 계획 file 졸리운_곰 2022.09.15 40
998 [국가기술자격 빅데이터분석기사][빅데이터분석기사 필기 요약] I.빅데이터 분석 기획 - 01. 빅데이터의 이해 (3) 졸리운_곰 2022.09.15 10
997 [국가기술자격 빅데이터분석기사][빅데이터분석기사 필기 요약] I.빅데이터 분석 기획 - 01. 빅데이터의 이해 (2) file 졸리운_곰 2022.09.13 17
996 [국가기술자격 빅데이터분석기사] [빅데이터분석기사 필기 요약] I.빅데이터 분석 기획 - 01. 빅데이터의 이해 (1) 졸리운_곰 2022.09.13 29
995 [국가기술자격 빅데이터분석기사] [인공지능] 베이즈 정리 ( Bayes' theorem ) file 졸리운_곰 2022.09.04 21
994 [ 국가기술자격 빅데이터분석기사 ] 빅데이터와 베이즈 정리 file 졸리운_곰 2022.09.04 42
993 [tensorflow] [인공지능] TensorFlow GPU 동작 확인 방법 file 졸리운_곰 2022.09.04 51
992 [국가기술자격 빅데이터분석기사] 빅데이터분석기사 - 필기 정리1 file 졸리운_곰 2022.09.01 119
991 [국가기술자격 빅데이터분석기사] 빅데이터분석기사 노트정리 공유 file 졸리운_곰 2022.09.01 171
990 [국가기술자격 빅데이터분석기사] 빅데이터 분석기사 : 개요 및 특징 file 졸리운_곰 2022.09.01 60
989 [국가기술자격 빅데이터분석기사] 빅데이터 분석 기사 개요 file 졸리운_곰 2022.09.01 24
988 [tensorflow] TensorFlow 2.x 에서 1.x 코드 사용하기 졸리운_곰 2022.08.07 67
987 [tensorflow] 텐서플로 - TF 1.*버전 vs 2.*버전 file 졸리운_곰 2022.08.07 56
» [Mysql] mysql에서 json 다루기 file 졸리운_곰 2022.08.02 52
985 [MySQL] MySQL 에서 JSON Data사용하기 졸리운_곰 2022.08.02 88
984 [데이터 수집 및 전처리] Crawling, Scraping file 졸리운_곰 2022.05.21 31
983 [데이터베이스 모델링] DAsP - 물리 데이터 모델링 [논리-물리 모델 변환] file 졸리운_곰 2022.05.07 71
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED