Files
TK-BOM-Project/database/init/20_purchase_confirmations.sql
Hyungi Ahn 83b90ef05c
Some checks failed
SonarQube Analysis / SonarQube Scan (push) Has been cancelled
feat: 자재 관리 페이지 대규모 개선
- 파이프 수량 계산 로직 수정 (단관 개수가 아닌 실제 길이 기반 계산)
- UI 전면 개편 (DevonThink 스타일의 간결하고 세련된 디자인)
- 자재별 그룹핑 로직 개선:
  * 플랜지: 동일 사양별 그룹핑, WN 스케줄 표시, ORIFICE 풀네임 표시
  * 피팅: 상세 타입 표시 (니플 길이, 엘보 각도/연결, 티 타입, 리듀서 타입 등)
  * 밸브: 동일 사양별 그룹핑, 타입/연결방식/압력 표시
  * 볼트: 크기/재질/길이별 그룹핑 (8SET → 개별 집계)
  * 가스켓: 동일 사양별 그룹핑, 재질/상세내역/두께 분리 표시
  * UNKNOWN: 원본 설명 전체 표시, 동일 항목 그룹핑
- 전체 카테고리 버튼 제거 (표시 복잡도 감소)
- 카테고리별 동적 컬럼 헤더 및 레이아웃 적용
2025-09-09 09:24:45 +09:00

73 lines
2.3 KiB
SQL

-- 구매 수량 확정 관련 테이블 생성
-- 1. 구매 확정 마스터 테이블
CREATE TABLE IF NOT EXISTS purchase_confirmations (
id SERIAL PRIMARY KEY,
job_no VARCHAR(50) NOT NULL,
file_id INTEGER REFERENCES files(id),
bom_name VARCHAR(255) NOT NULL,
revision VARCHAR(50) NOT NULL DEFAULT 'Rev.0',
confirmed_at TIMESTAMP NOT NULL,
confirmed_by VARCHAR(100) NOT NULL,
is_active BOOLEAN NOT NULL DEFAULT TRUE,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- 2. 확정된 구매 품목 테이블
CREATE TABLE IF NOT EXISTS confirmed_purchase_items (
id SERIAL PRIMARY KEY,
confirmation_id INTEGER REFERENCES purchase_confirmations(id) ON DELETE CASCADE,
item_code VARCHAR(100) NOT NULL,
category VARCHAR(50) NOT NULL,
specification TEXT,
size VARCHAR(100),
material VARCHAR(100),
bom_quantity DECIMAL(15,3) NOT NULL DEFAULT 0,
calculated_qty DECIMAL(15,3) NOT NULL DEFAULT 0,
unit VARCHAR(20) NOT NULL DEFAULT 'EA',
safety_factor DECIMAL(5,3) NOT NULL DEFAULT 1.0,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- 3. files 테이블에 확정 관련 컬럼 추가 (이미 있으면 무시)
ALTER TABLE files
ADD COLUMN IF NOT EXISTS purchase_confirmed BOOLEAN DEFAULT FALSE,
ADD COLUMN IF NOT EXISTS confirmed_at TIMESTAMP,
ADD COLUMN IF NOT EXISTS confirmed_by VARCHAR(100);
-- 인덱스 생성
CREATE INDEX IF NOT EXISTS idx_purchase_confirmations_job_revision
ON purchase_confirmations(job_no, revision, is_active);
CREATE INDEX IF NOT EXISTS idx_confirmed_purchase_items_confirmation
ON confirmed_purchase_items(confirmation_id);
CREATE INDEX IF NOT EXISTS idx_confirmed_purchase_items_category
ON confirmed_purchase_items(category);
CREATE INDEX IF NOT EXISTS idx_files_purchase_confirmed
ON files(purchase_confirmed);
-- 코멘트 추가
COMMENT ON TABLE purchase_confirmations IS '구매 수량 확정 마스터 테이블';
COMMENT ON TABLE confirmed_purchase_items IS '확정된 구매 품목 상세 테이블';
COMMENT ON COLUMN files.purchase_confirmed IS '구매 수량 확정 여부';
COMMENT ON COLUMN files.confirmed_at IS '구매 수량 확정 시간';
COMMENT ON COLUMN files.confirmed_by IS '구매 수량 확정자';