프로젝트

일반

사용자정보

2025/20.개발산출물/01.DB 설계 » iitp_db_schemas_init-deletion_and_creation_admin.sql

이환희, 2025-12-19 05:01

 
-- ## iitp DB Schemas - Initial setup - Creation and Delete if tables exists
-- ## ver 0.0.5 last updated data : 2025.08.18
-- ## Only for PostgreSQL
-- ## Open API Admin 관리용 Admin 서비스 데이터용 테이블 생성 스크립트
-- ##


-- ################################################
-- ## ADMIN 시스템 테이블 생성
-- ################################################

-- #### IITP Admin Account(user) 정보 테이블 ####

-- # public.sys_adm_account definition

DROP TABLE IF EXISTS public.sys_adm_account;


CREATE TABLE public.sys_adm_account (
adm_id int4 GENERATED BY DEFAULT AS IDENTITY( INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 START 1 CACHE 1 NO CYCLE) NOT NULL, -- system id, 고유 식별자 (자동 증가)
login_id VARCHAR(128) NOT NULL, -- admin login id
password char(60) NOT NULL, -- admin login password (bcrypt Hassing)
name VARCHAR(90) NOT NULL, -- admin name
roles varchar(8) NOT NULL, -- admin role, "sys_admin_roles" comm code 참조
status char(1) DEFAULT 'A' NOT NULL, -- 데이터 상태, "data_status" comm code 참조
del_yn char(1) DEFAULT 'N'::bpchar NOT NULL, -- 삭제여부 (Y: 삭제)

latest_login_at timestamptz, -- latest login time
affiliation VARCHAR(60), -- admin 소속
description VARCHAR(600), -- admin 설명
note VARCHAR(600), -- 비고
created_at timestamptz DEFAULT CURRENT_TIMESTAMP NOT NULL, -- 레코드 생성 시각
updated_at timestamptz DEFAULT CURRENT_TIMESTAMP, -- 레코드 수정 시각
deleted_at timestamptz NULL, -- 삭제 일시 (논리 삭제 시 기록)
created_by varchar(40) NOT NULL, -- 데이터 생성자 (SYS-BACH, SYS-MANUAL, BY-USER, admin name), "sys_work_type" comm code 참조
updated_by varchar(40) NULL, -- 데이터 수정자
deleted_by varchar(40) NULL, -- 데이터 삭제자
CONSTRAINT pkey_sys_adm_account PRIMARY KEY (adm_id)
);

CREATE UNIQUE INDEX uidx_sys_adm_account_login ON public.sys_adm_account USING btree (login_id);
CREATE INDEX idx_sys_adm_account_name ON public.sys_adm_account USING btree (name);
CREATE INDEX idx_sys_adm_account_role_status ON public.sys_adm_account USING btree (roles, status);
COMMENT ON TABLE public.sys_adm_account IS 'IITP Admin Account(user) 정보 테이블';

COMMENT ON COLUMN public.sys_adm_account.adm_id IS ' system id, 고유 식별자 (자동 증가)';
COMMENT ON COLUMN public.sys_adm_account.login_id IS 'admin login id';
COMMENT ON COLUMN public.sys_adm_account.password IS 'admin login password (bcrypt Hassing), 초기 비번(12345!!!)';
COMMENT ON COLUMN public.sys_adm_account.name IS 'admin name';

COMMENT ON COLUMN public.sys_adm_account.roles IS 'admin role, "sys_admin_roles" comm code 참조';
COMMENT ON COLUMN public.sys_adm_account.status IS '"data_status" comm code 참조';
COMMENT ON COLUMN public.sys_adm_account.del_yn IS '삭제여부 (Y: 삭제)';

COMMENT ON COLUMN public.sys_adm_account.affiliation IS 'admin 소속';
COMMENT ON COLUMN public.sys_adm_account.description IS 'admin 설명';
COMMENT ON COLUMN public.sys_adm_account.note IS '비고';

COMMENT ON COLUMN public.sys_adm_account.latest_login_at IS '마지막 로그인 시각';

COMMENT ON COLUMN public.sys_adm_account.created_at IS '레코드 생성 시각';
COMMENT ON COLUMN public.sys_adm_account.updated_at IS '레코드 수정 시각';
COMMENT ON COLUMN public.sys_adm_account.deleted_at IS '삭제 일시 (논리 삭제 시 기록)';
COMMENT ON COLUMN public.sys_adm_account.created_by IS '데이터 생성자 (SYS-BACH, SYS-MANUAL, BY-USER, admin name), "sys_work_type" comm code 참조';
COMMENT ON COLUMN public.sys_adm_account.updated_by IS '데이터 수정자';
COMMENT ON COLUMN public.sys_adm_account.deleted_by IS '데이터 삭제자';




-- #### IITP 공지사항 게시 정보 테이블 ####

-- # public.sys_notice definition

DROP TABLE IF EXISTS public.sys_notice;


CREATE TABLE sys_notice (
notice_id int4 GENERATED BY DEFAULT AS IDENTITY( INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 START 1 CACHE 1 NO CYCLE) NOT NULL, -- 공지사항 고유 ID
title VARCHAR(300) NOT NULL, -- 공지 제목
content VARCHAR(6000) NOT NULL, -- 공지 본문 내용
notice_type CHAR(1) NOT null DEFAULT 'G' CHECK (notice_type IN ('G', 'S', 'E')), -- 공지 유형 (예: G(general), S(system), E(event))
pinned_yn CHAR(1) DEFAULT 'N', -- 상단 고정 여부 (Y 시 우선 노출)
public_yn CHAR(1) DEFAULT 'Y', -- 공개 여부 (N이면 비공개 또는 관리자 전용)
posted_at timestamptz DEFAULT CURRENT_TIMESTAMP, -- 게시 일시
start_dt DATE, -- 공지 시작일 (노출 시작일)
end_dt DATE, -- 공지 종료일 (노출 종료일)
created_by VARCHAR(100), -- 작성자
updated_by VARCHAR(100), -- 수정자
created_at timestamptz DEFAULT CURRENT_TIMESTAMP, -- 생성 일시
updated_at timestamptz, -- 수정 일시
CONSTRAINT pkey_sys_notice PRIMARY KEY (notice_id)
);

CREATE INDEX idx_sys_notice_type_dt ON public.sys_notice USING btree (notice_type, start_dt,end_dt);

COMMENT ON TABLE sys_notice IS '공지사항 게시 정보 테이블';

COMMENT ON COLUMN sys_notice.notice_id IS '공지사항 고유 식별자';
COMMENT ON COLUMN sys_notice.title IS '공지 제목';
COMMENT ON COLUMN sys_notice.content IS '공지 본문 텍스트';
COMMENT ON COLUMN sys_notice.notice_type IS '공지 유형 (예: G(general), S(system), E(event))';
COMMENT ON COLUMN sys_notice.pinned_yn IS '공지 상단 고정 여부 (Y 시 우선 노출)';
COMMENT ON COLUMN sys_notice.public_yn IS '공개 여부 (N이면 비공개 또는 관리자 전용)';
COMMENT ON COLUMN sys_notice.posted_at IS '공지 게시 일시';
COMMENT ON COLUMN sys_notice.start_dt IS '공지 노출 시작일';
COMMENT ON COLUMN sys_notice.end_dt IS '공지 노출 종료일';
COMMENT ON COLUMN sys_notice.created_by IS '공지 작성자 ID 또는 이름';
COMMENT ON COLUMN sys_notice.updated_by IS '공지 수정자 ID 또는 이름';
COMMENT ON COLUMN sys_notice.created_at IS '레코드 생성 시각';
COMMENT ON COLUMN sys_notice.updated_at IS '레코드 수정 시각';





-- #### IITP 자주 묻는 질문(FAQ) 정보 테이블 ####

-- # public.sys_faq definition

DROP TABLE IF EXISTS public.sys_faq;

CREATE TABLE public.sys_faq (
faq_id int4 GENERATED BY DEFAULT AS IDENTITY( INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 START 1 CACHE 1 NO CYCLE) NOT NULL, -- system id, 고유 식별자 (자동 증가)
faq_type VARCHAR(12) NOT NULL, -- FAQ 유형, "faq_type" comm code 참조
question VARCHAR(600) NOT NULL, -- 질문
answer VARCHAR(3000) NOT NULL, -- 답변
sort_order INT DEFAULT 0, -- 정렬 우선순위
hit_cnt INT DEFAULT 0, -- 조회수
use_yn CHAR(1) DEFAULT 'Y', -- 사용 여부 (Y/N)
created_at timestamptz DEFAULT CURRENT_TIMESTAMP,
updated_at timestamptz DEFAULT CURRENT_TIMESTAMP,
created_by varchar(40),
updated_by varchar(40),
CONSTRAINT pkey_sys_faq PRIMARY KEY (faq_id)
);
CREATE INDEX idx_sys_faq_type_sort ON public.sys_faq USING btree (faq_type, sort_order,use_yn);


COMMENT ON TABLE public.sys_faq IS '자주 묻는 질문(FAQ) 정보 테이블';

COMMENT ON COLUMN public.sys_faq.faq_id IS 'FAQ 고유 ID';
COMMENT ON COLUMN public.sys_faq.faq_type IS 'FAQ 유형, "faq_type" comm code 참조';
COMMENT ON COLUMN public.sys_faq.question IS 'FAQ 질문';
COMMENT ON COLUMN public.sys_faq.answer IS 'FAQ 답변';
COMMENT ON COLUMN public.sys_faq.sort_order IS '정렬 순서';
COMMENT ON COLUMN public.sys_faq.hit_cnt IS 'FAQ 조회수';
COMMENT ON COLUMN public.sys_faq.use_yn IS '사용 여부 (Y/N))';


COMMENT ON COLUMN public.sys_faq.created_by IS '등록자 ID 또는 이름';
COMMENT ON COLUMN public.sys_faq.updated_by IS '수정자 ID 또는 이름';
COMMENT ON COLUMN public.sys_faq.created_at IS '등록 일시';
COMMENT ON COLUMN public.sys_faq.updated_at IS '수정 일시';




-- #### IITP 일반 사용자 QnA 테이블 (질문과 답변 포함) ####

-- # public.sys_qna definition

DROP TABLE IF EXISTS public.sys_qna;

CREATE TABLE public.sys_qna (
qna_id BIGSERIAL NOT NULL, -- 질문 고유 식별자
user_id int4 NOT NULL, -- 작성자 system ID
qna_type VARCHAR(32) NOT NULL, -- 질문 유형, "qna_type" comm code 참조
title VARCHAR(600) NOT NULL, -- 질문 제목
content VARCHAR(6000) NOT NULL, -- 질문 내용
secret_yn CHAR(1) DEFAULT 'N', -- 비공개 여부 (Y: 비공개, N: 공개)
writer_name varchar(90), -- 작성자 이름 (선택 입력)
answer_content VARCHAR(6000), -- 답변 내용
answered_by varchar(40), -- 답변자 ID 또는 이름
answered_yn CHAR(1) DEFAULT 'N', -- 답변 공개(완료) 여부 (Y: 공개(완료), N: 비공개(미답변))
hit_cnt INT DEFAULT 0, -- 조회수
del_yn char(1) DEFAULT 'N'::bpchar NOT NULL, -- 삭제여부 (Y: 삭제)
answered_at timestamptz, -- 답변 일시
created_at timestamptz NOT NULL DEFAULT CURRENT_TIMESTAMP, -- 질문 등록일시
updated_at timestamptz DEFAULT CURRENT_TIMESTAMP, -- 마지막 수정일시
deleted_at timestamptz, -- 삭제 일시
created_by varchar(40), -- 생성자
updated_by varchar(40), -- 수정자
deleted_by varchar(40), -- 삭제자
CONSTRAINT pkey_sys_qna PRIMARY KEY (qna_id)
);
CREATE INDEX idx_sys_qna_type_screct ON public.sys_qna USING btree (qna_type, secret_yn);
CREATE INDEX idx_sys_qna_type_sort ON public.sys_qna USING btree (hit_cnt, created_at);


COMMENT ON TABLE public.sys_qna IS '일반 사용자 QnA 테이블 (질문과 답변 포함)';

COMMENT ON COLUMN public.sys_qna.qna_id IS 'QnA 고유 식별자 (Primary Key)';
COMMENT ON COLUMN public.sys_qna.user_id IS '작성자 system ID ';
COMMENT ON COLUMN public.sys_qna.qna_type IS 'QnA 질문 유형, "qna_type" comm code 참조';
COMMENT ON COLUMN public.sys_qna.title IS '질문 제목';
COMMENT ON COLUMN public.sys_qna.content IS '질문 본문 내용';
COMMENT ON COLUMN public.sys_qna.secret_yn IS '비공개 여부 (Y: 비공개, N: 공개)';
COMMENT ON COLUMN public.sys_qna.writer_name IS '작성자 이름 (옵션)';
COMMENT ON COLUMN public.sys_qna.answer_content IS '답변 내용';
COMMENT ON COLUMN public.sys_qna.answered_by IS '답변 작성자 ID 또는 이름';
COMMENT ON COLUMN public.sys_qna.answered_yn IS '답변 공개(완료) 여부 (Y: 공개(완료), N: 비공개(미답변))';
COMMENT ON COLUMN public.sys_qna.hit_cnt IS 'QnA 조회수';
COMMENT ON COLUMN public.sys_qna.del_yn IS '삭제여부 (Y: 삭제)';
COMMENT ON COLUMN public.sys_qna.answered_at IS '답변 등록 일시';
COMMENT ON COLUMN public.sys_qna.created_at IS '질문 등록 일시';
COMMENT ON COLUMN public.sys_qna.updated_at IS '질문 수정 일시';
COMMENT ON COLUMN public.sys_qna.deleted_at IS '삭제 일시 (soft delete)';
COMMENT ON COLUMN public.sys_qna.created_by IS '생성자 ID';
COMMENT ON COLUMN public.sys_qna.updated_by IS '수정자 ID';
COMMENT ON COLUMN public.sys_qna.deleted_by IS '삭제자 ID';







-- ################################################
-- ## 시스템 로그 기록
-- ################################################



-- #### IITP 사용자 access(login/logout) 이력 테이블 ####

-- # public.sys_log_user_access definition

DROP TABLE IF EXISTS public.sys_log_user_access;

CREATE TABLE public.sys_log_user_access (
log_id BIGSERIAL NOT NULL, -- 로그 고유 ID
user_id int4 NOT NULL, -- 사용자 ID
user_type CHAR(1) NOT NULL CHECK (user_type IN ('U', 'A')), -- 사용자 유형
log_type VARCHAR(16) NOT NULL CHECK (log_type IN ('LOGIN', 'LOGOUT', 'LOGOUT-T-EXP')), -- 수행한 액션 종류 (예: LOGIN, LOGOUT, LOGOUT-T-EXP)
act_result CHAR(1) NOT NULL CHECK (act_result IN ('S', 'F')), -- 액션 결과 ( S, F)
err_code VARCHAR(10), -- 실패 시 에러 코드
err_msg VARCHAR(200), -- 실패 시 에러 메시지
ip_addr VARCHAR(50), -- 요청 IP 주소
user_agent VARCHAR(512), -- 사용자 디바이스 정보 (브라우저 등)
access_tm timestamptz NOT NULL DEFAULT CURRENT_TIMESTAMP, -- access 시각
created_at timestamptz DEFAULT CURRENT_TIMESTAMP,
CONSTRAINT pkey_sys_log_user_access PRIMARY KEY (log_id)
);
CREATE INDEX idx_sys_log_user_access_user_type ON public.sys_log_user_access USING btree (user_id, user_type,log_type);


COMMENT ON TABLE public.sys_log_user_access IS '사용자 access(login/logout) 이력 테이블';

COMMENT ON COLUMN public.sys_log_user_access.log_id IS '로그 고유 ID';
COMMENT ON COLUMN public.sys_log_user_access.user_id IS '사용자 ID';
COMMENT ON COLUMN public.sys_log_user_access.user_type IS '사용자 유형(U:User, A:Admin)';

COMMENT ON COLUMN public.sys_log_user_access.log_type IS '수행한 액션 (예: LOGIN, LOGOUT,LOGOUT-T-EXP)';
COMMENT ON COLUMN public.sys_log_user_access.act_result IS '성공 여부( S:성공, F:실패)';
COMMENT ON COLUMN public.sys_log_user_access.err_code IS '에러 발생 시 코드';
COMMENT ON COLUMN public.sys_log_user_access.err_msg IS '에러 발생 시 상세 메시지';
COMMENT ON COLUMN public.sys_log_user_access.ip_addr IS '요청을 보낸 클라이언트 IP';
COMMENT ON COLUMN public.sys_log_user_access.user_agent IS '사용자 디바이스 정보 (브라우저 등)';
COMMENT ON COLUMN public.sys_log_user_access.access_tm IS 'access 시각';
COMMENT ON COLUMN public.sys_log_user_access.created_at IS '등록 일시';




-- #### IITP 어드민/사용자 데이터 변경 이력 테이블 ####

-- # public.sys_log_change_his definition

DROP TABLE IF EXISTS public.sys_log_change_his;

CREATE TABLE sys_log_change_his (
log_id BIGSERIAL PRIMARY KEY,
actor_type CHAR(1) NOT NULL CHECK (actor_type IN ('U', 'A')), -- 사용자 유형
actor_id BIGINT NOT NULL, -- user_id or admin_id depending on actor_type

action_type VARCHAR(36) NOT NULL, -- 변경 타입 (예: 'DEL_ACCOUNT', 'EDIT_ACCOUNT')
target_type VARCHAR(64), -- 변경 대상 타입(예: 'USER_PROFILE', 'ADMIN_MENU', 'ROLE', etc.)
target_id BIGINT, -- 대상 ID

act_result CHAR(1) NOT NULL CHECK (act_result IN ('S', 'F')), -- 액션 결과 ( S, F)
chg_summary JSONB, -- 주요 변경 내용 요약, 예: {"bf": {...}, "af: {...}}
err_code VARCHAR(10), -- 실패 시 에러 코드
err_msg VARCHAR(200), -- 실패 시 에러 메시지
ip_addr VARCHAR(50), -- 요청 IP 주소
user_agent VARCHAR(512), -- 사용자 디바이스 정보 (브라우저 등)

act_tm timestamptz NOT NULL DEFAULT CURRENT_TIMESTAMP, -- action 시각
created_at timestamptz DEFAULT CURRENT_TIMESTAMP
);
CREATE INDEX idx_sys_log_change_his_act_type_id ON public.sys_log_change_his USING btree (actor_type, actor_id, action_type);
CREATE INDEX idx_sys_log_change_his_tgt_type_id ON public.sys_log_change_his USING btree (target_type, target_id);


COMMENT ON TABLE public.sys_log_change_his IS '어드민/사용자 데이터 변경 이력 테이블';

COMMENT ON COLUMN public.sys_log_change_his.log_id IS '로그 고유 ID';
COMMENT ON COLUMN public.sys_log_change_his.actor_type IS '사사용자 유형(U:User, A:Admin)';
COMMENT ON COLUMN public.sys_log_change_his.actor_id IS 'user_id or admin_id depending on actor_type';

COMMENT ON COLUMN public.sys_log_change_his.action_type IS '변경 타입 (예: DEL_ACCOUNT, EDIT_ACCOUNT)';
COMMENT ON COLUMN public.sys_log_change_his.target_type IS '변경 대상 타입 (예: USR_PROFILE, ADM_MENU, ROLE, etc.)';
COMMENT ON COLUMN public.sys_log_change_his.target_id IS '대상 ID';

COMMENT ON COLUMN public.sys_log_change_his.act_result IS '성공 여부( S:성공, F:실패)';
COMMENT ON COLUMN public.sys_log_change_his.chg_summary IS '주요 변경 내용 요약, 예: {"bf": {...}, "af: {...}}';

COMMENT ON COLUMN public.sys_log_change_his.err_code IS '에러 발생 시 코드';
COMMENT ON COLUMN public.sys_log_change_his.err_msg IS '에러 발생 시 상세 메시지';
COMMENT ON COLUMN public.sys_log_change_his.ip_addr IS '요청을 보낸 클라이언트 IP';
COMMENT ON COLUMN public.sys_log_change_his.user_agent IS '사용자 디바이스 정보 (브라우저 등)';
COMMENT ON COLUMN public.sys_log_change_his.act_tm IS 'action 시각';
COMMENT ON COLUMN public.sys_log_change_his.created_at IS '등록 일시';









-- ################################################
-- ## 통계 데이터 수집 기록
-- ################################################

-- #### KOSIS 통계 데이터 수집 기록 ####

-- # public.sys_ext_api_info definition

-- Drop table if table exists

CREATE TABLE public.sys_log_stats_intg_his (
log_id int8 GENERATED BY DEFAULT AS identity
intg_tbl_id VARCHAR(50) NOT NULL, -- 데이터 동합할 내부 db table id
stat_tbl_id varchar(40) NOT NULL, -- 원데이터 통계 id
action_type varchar(24) NOT NULL, -- action type "log_his_stat_act_type" comm code 참조
ret_yn char(1) NOT NULL, -- action 실패 여부
err_code char(6), -- 실패시 에러 코드
err_msg varchar(300), -- 실패시 에러 메시지
created_at timestamptz DEFAULT CURRENT_TIMESTAMP NOT NULL, -- 레코드 생성 시각
created_by varchar(40) NULL, -- 데이터 생성자 (SYS-BACH, SYS-MANUAL, BY-USER, admin name), "sys_work_type" comm code 참조
CONSTRAINT pkey_log_his_stats_intg PRIMARY KEY (log_id)
};
COMMENT ON COLUMN public.log_his_stats_intg.created_at IS '레코드 생성 시각';
COMMENT ON COLUMN public.log_his_stats_intg.created_by IS '데이터 생성자 (SYS-BACH, SYS-MANUAL, BY-USER, admin name), "sys_work_type" comm code 참조';
(4-4/11)