일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- docker
- Elasticsearch
- TensorFlow
- MySQL
- Kafka
- licence delete curl
- Mac
- 차트
- token filter test
- sort
- Test
- aggs
- query
- Java
- License
- API
- matplotlib
- plugin
- 900gle
- license delete
- springboot
- analyzer test
- zip 파일 암호화
- zip 암호화
- Python
- flask
- high level client
- aggregation
- ELASTIC
- 파이썬
Archives
- Today
- Total
개발잡부
[Mysql] Procedure 본문
반응형
CREATE PROCEDURE `PROC_TEST` (
PARAM_NAME VARCHAR(20) -- 파라미터 선언
, PARAM_AGE INTEGER
)
BEGIN
DECLARE PARAM_NUM INTEGER; -- 변수 선언
SELECT COUNT(*) + 1
INTO PARAM_NUM -- 변수에 값 할당
FROM TB1;
-- INSERT 문 수행
INSERT INTO TB1(NUM, NAME, AGE) VALUES(PARAM_NUM, PARAM_NAME, PARAM_AGE);
END
Sample
CREATE DEFINER=`master`@`%` PROCEDURE `job_mass_process_category_change`()
BEGIN
DECLARE PV_JOB_SEQ BIGINT default null;
DECLARE PV_SRC_CATE VARCHAR(16) default null;
DECLARE PV_DST_CATE VARCHAR(16) default null;
DECLARE PV_LOOP_CTRL BIGINT default 1;
DECLARE PV_EFFECTED_ROWS BIGINT default 0;
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
GET DIAGNOSTICS CONDITION 1
@SQL_STATE = RETURNED_SQLSTATE
, @ERR_NO = MYSQL_ERRNO
, @ERR_MSG = MESSAGE_TEXT;
INSERT INTO db_process_err_log
(proc_owner, ref_key, error_msg)
VALUES('job_mass_process_category_change', CONCAT(PV_SRC_CATE, ':', PV_DST_CATE), @ERROR_INFO);
END;
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
SELECT idx, job_param1, job_param2 INTO PV_JOB_SEQ, PV_SRC_CATE, PV_DST_CATE
FROM mass_process_job_list
WHERE process_type = 'CATEGORY_CHANGE'
AND job_state <> 'COMPLETE'
ORDER BY reg_dtm ASC
LIMIT 1;
IF PV_JOB_SEQ IS NOT NULL AND PV_SRC_CATE IS NOT NULL AND PV_DST_CATE IS NOT NULL THEN
-- Run Step 1
UPDATE mass_process_job_list
SET run_step = 1
, effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
WHILE PV_LOOP_CTRL > 0
DO
SET PV_LOOP_CTRL = 0;
UPDATE ws_product_item2item_category_map
SET cate_mst_cd = PV_DST_CATE
WHERE cate_mst_cd = PV_SRC_CATE
LIMIT 1000;
SET PV_LOOP_CTRL = ROW_COUNT();
SET PV_EFFECTED_ROWS = PV_EFFECTED_ROWS + PV_LOOP_CTRL;
UPDATE mass_process_job_list
SET effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
COMMIT;
END WHILE;
-- Run Step 2
UPDATE mass_process_job_list
SET run_step = 2
, effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
SET PV_LOOP_CTRL = 1;
WHILE PV_LOOP_CTRL > 0
DO
UPDATE ws_vendor_category_map
SET cate_mst_cd = PV_DST_CATE
WHERE cate_mst_cd = PV_SRC_CATE
LIMIT 1000;
SET PV_LOOP_CTRL = ROW_COUNT();
SET PV_EFFECTED_ROWS = PV_EFFECTED_ROWS + PV_LOOP_CTRL;
UPDATE mass_process_job_list
SET effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
COMMIT;
END WHILE;
-- Run Step 3
UPDATE mass_process_job_list
SET run_step = 3
, effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
SET PV_LOOP_CTRL = 1;
WHILE PV_LOOP_CTRL > 0
DO
UPDATE ws_product_category_map
SET cate_mst_cd = PV_DST_CATE
WHERE cate_mst_cd = PV_SRC_CATE
LIMIT 1000;
SET PV_LOOP_CTRL = ROW_COUNT();
SET PV_EFFECTED_ROWS = PV_EFFECTED_ROWS + PV_LOOP_CTRL;
UPDATE mass_process_job_list
SET effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
COMMIT;
END WHILE;
-- Run Step 4
UPDATE mass_process_job_list
SET run_step = 4
, effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
SET PV_LOOP_CTRL = 1;
WHILE PV_LOOP_CTRL > 0
DO
UPDATE ws_product_category_map
SET auto_cate_mst_cd = PV_SRC_CATE
WHERE auto_cate_mst_cd = PV_SRC_CATE
LIMIT 1000;
SET PV_LOOP_CTRL = ROW_COUNT();
SET PV_EFFECTED_ROWS = PV_EFFECTED_ROWS + PV_LOOP_CTRL;
UPDATE mass_process_job_list
SET effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
COMMIT;
END WHILE;
UPDATE mass_process_job_list
SET job_state = 'COMPLETE'
, effected_rows = PV_EFFECTED_ROWS
WHERE idx = PV_JOB_SEQ;
END IF;
END
반응형
'Database' 카테고리의 다른 글
[mysql] left join 안에서 group_concat (0) | 2023.03.14 |
---|---|
[mysql] PRIMARY KEY, UNIQUE KEY (0) | 2022.04.23 |
[Mysql] View (0) | 2022.04.01 |
[MySql] Event Scheduler (0) | 2022.04.01 |
[MySql] Union Query (0) | 2022.03.15 |
Comments