FK가 기존 unique_user_type_year 인덱스를 참조하므로 새 인덱스를 먼저 추가한 뒤 기존 것을 삭제해야 함 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
93 lines
4.8 KiB
SQL
93 lines
4.8 KiB
SQL
-- Sprint 001: 연차/휴가 관리 시스템 개선 마이그레이션
|
|
-- 비파괴적(additive) 변경만 수행
|
|
-- 실행: 수동 또는 서버 시작 시
|
|
|
|
-- ============================================================
|
|
-- 1. departments에 팀장 컬럼 추가
|
|
-- ============================================================
|
|
ALTER TABLE departments
|
|
ADD COLUMN IF NOT EXISTS leader_user_id INT NULL
|
|
COMMENT '팀장(부서장) sso_users.user_id';
|
|
|
|
-- ============================================================
|
|
-- 2. dept_approval_authority (부서별 승인권한) 신규
|
|
-- ============================================================
|
|
CREATE TABLE IF NOT EXISTS dept_approval_authority (
|
|
id INT AUTO_INCREMENT PRIMARY KEY,
|
|
department_id INT NOT NULL COMMENT '대상 부서',
|
|
approval_type VARCHAR(50) NOT NULL COMMENT '승인유형 (VACATION, PURCHASE 등)',
|
|
approver_user_id INT NOT NULL COMMENT '승인자 sso_users.user_id',
|
|
priority INT DEFAULT 1 COMMENT '승인 순서 (다단계 승인 시)',
|
|
is_active BOOLEAN DEFAULT TRUE,
|
|
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
|
FOREIGN KEY (department_id) REFERENCES departments(department_id) ON DELETE CASCADE,
|
|
FOREIGN KEY (approver_user_id) REFERENCES sso_users(user_id),
|
|
UNIQUE KEY uq_dept_type_approver (department_id, approval_type, approver_user_id)
|
|
) COMMENT '부서별 행정 승인권한 (시스템 접근권한과 별개)';
|
|
|
|
-- ============================================================
|
|
-- 3. vacation_settings (연차 계산 규칙 설정) 신규
|
|
-- ============================================================
|
|
CREATE TABLE IF NOT EXISTS vacation_settings (
|
|
id INT AUTO_INCREMENT PRIMARY KEY,
|
|
setting_key VARCHAR(100) NOT NULL UNIQUE,
|
|
setting_value TEXT NOT NULL,
|
|
description TEXT,
|
|
updated_by INT,
|
|
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
|
FOREIGN KEY (updated_by) REFERENCES sso_users(user_id)
|
|
) COMMENT '연차 계산 규칙 설정';
|
|
|
|
INSERT IGNORE INTO vacation_settings (setting_key, setting_value, description) VALUES
|
|
('annual_leave_first_year_rule', 'MONTHLY', '1년 미만: MONTHLY(월 1일) / NONE(없음)'),
|
|
('annual_leave_base_days', '15', '1년차 기본 연차일수'),
|
|
('annual_leave_increment_per_years', '2', '추가 1일 부여 간격 (년)'),
|
|
('annual_leave_max_days', '25', '연차 최대 일수'),
|
|
('long_service_threshold_years', '5', '장기근속 연차 부여 기준 (년)'),
|
|
('long_service_bonus_days', '3', '장기근속 추가 연차 일수'),
|
|
('long_service_expiry', 'UNTIL_RESIGN', '장기근속 연차 만료: UNTIL_RESIGN(퇴사까지) / YEARLY(매년)'),
|
|
('long_service_auto_grant', 'true', '장기근속 연차 자동 부여 여부'),
|
|
('carry_over_enabled', 'true', '이월연차 허용 여부'),
|
|
('carry_over_max_days', '0', '이월 최대 일수 (0=무제한)'),
|
|
('carry_over_expiry_month', '2', '이월연차 사용 기한 (월)');
|
|
|
|
-- ============================================================
|
|
-- 4. sp_vacation_balances 확장 (balance_type, expires_at 추가)
|
|
-- ============================================================
|
|
ALTER TABLE sp_vacation_balances
|
|
ADD COLUMN IF NOT EXISTS balance_type ENUM('AUTO','MANUAL','CARRY_OVER','LONG_SERVICE','COMPANY_GRANT')
|
|
DEFAULT 'AUTO' COMMENT '부여 유형',
|
|
ADD COLUMN IF NOT EXISTS expires_at DATE NULL COMMENT '만료일 (NULL=해당연도말)';
|
|
|
|
-- UNIQUE KEY 변경: balance_type을 포함하여 같은 user/type/year에 AUTO + LONG_SERVICE 공존 허용
|
|
-- 새 인덱스를 먼저 추가해야 FK(user_id)가 새 인덱스를 참조 가능
|
|
ALTER TABLE sp_vacation_balances
|
|
ADD UNIQUE KEY unique_user_type_year_btype (user_id, vacation_type_id, year, balance_type);
|
|
|
|
ALTER TABLE sp_vacation_balances
|
|
DROP INDEX IF EXISTS unique_user_type_year;
|
|
|
|
-- ============================================================
|
|
-- 5. sso_users에 장기근속 제외 플래그
|
|
-- ============================================================
|
|
ALTER TABLE sso_users
|
|
ADD COLUMN IF NOT EXISTS long_service_excluded BOOLEAN DEFAULT FALSE
|
|
COMMENT '장기근속 연차 제외 대상';
|
|
|
|
-- ============================================================
|
|
-- 6. company_holidays (전사 휴가일 관리) 신규
|
|
-- ============================================================
|
|
CREATE TABLE IF NOT EXISTS company_holidays (
|
|
id INT AUTO_INCREMENT PRIMARY KEY,
|
|
holiday_date DATE NOT NULL,
|
|
holiday_name VARCHAR(100) NOT NULL COMMENT '휴가명',
|
|
holiday_type ENUM('PAID','ANNUAL_DEDUCT') NOT NULL
|
|
COMMENT 'PAID=유급휴가(회사부여), ANNUAL_DEDUCT=연차차감',
|
|
description TEXT,
|
|
created_by INT NOT NULL,
|
|
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
FOREIGN KEY (created_by) REFERENCES sso_users(user_id),
|
|
UNIQUE KEY uq_holiday_date (holiday_date)
|
|
) COMMENT '전사 휴가일 관리';
|