CREATE TABLE IF NOT EXISTS new_details_staging
(
e_id NUMBER(10),
e_name VARCHAR2(30),
portal_desc VARCHAR2(50),
risk_dec VARCHAR2(50),
CONSTRAINT pk_new_details_staging PRIMARY KEY (e_id)
);
INSERT IGNORE INTO new_details_staging
VALUES (11, 'A', 'AA', 'High');
INSERT IGNORE INTO new_details_staging
VALUES (22, 'B', 'BB', 'Low');
CREATE TABLE IF NOT EXISTS lookup_ref
(
ref_id NUMBER(10),
ref_typ VARCHAR2(30),
ref_typ_desc VARCHAR2(20),
CONSTRAINT pk_lookup_ref PRIMARY KEY (ref_id)
);
INSERT IGNORE INTO lookup_ref
VALUES (181, 'portal', 'AA');
INSERT IGNORE INTO lookup_ref
VALUES (182, 'portal', 'BB');
INSERT IGNORE INTO lookup_ref
VALUES (183, 'risk', 'High');
INSERT IGNORE INTO lookup_ref
VALUES (184, 'risk', 'Low');
CREATE TABLE IF NOT EXISTS new_details_main
(
e_id NUMBER(10),
e_name VARCHAR2(30),
portal NUMBER(20),
risk NUMBER(20),
CONSTRAINT pk_new_details_main PRIMARY KEY (e_id)
);
COMMIT;
나도:
INSERT IGNORE INTO new_details_main (e_id, e_name, portal,risk)
SELECT
n.e_id,
n.e_name,
(SELECT lr.ref_id
FROM lookup_ref lr
WHERE lr.ref_typ = 'portal'
AND lr.ref_typ_desc = n.portal_desc),
(SELECT lr.ref_id
FROM lookup_ref lr
WHERE lr.ref_typ = 'risk'
AND lr.ref_typ_desc = n.risk_dec)
FROM
new_details_staging n;
지금,나는 삽입하는 몇 가지 기록하고 그것은 정확한 결과 하지만 실제로 있 40k+기록을 그래서 나는 그것을 믿는 것입니다 제공 성능 문제한다. 어떤 방법을 레코드를 삽입하려면 빠르기 때문에 나는 절차에 대한 이 삽입? 은 거기에 다른 어떤 이는 내가 쓸 수 있는 삽입 쿼리 내부의 절차를 밟아야 합니까?