✅ 백엔드 구조 개선: - DatabaseService: 공통 DB 쿼리 로직 통합 - FileUploadService: 파일 업로드 로직 모듈화 및 트랜잭션 관리 개선 - 서비스 레이어 패턴 도입으로 코드 재사용성 향상 ✅ 프론트엔드 컴포넌트 개선: - LoadingSpinner, ErrorMessage, ConfirmDialog 공통 컴포넌트 생성 - 재사용 가능한 컴포넌트 라이브러리 구축 - deprecated/backup 파일들 완전 제거 ✅ 성능 최적화: - optimize_database.py: 핵심 DB 인덱스 자동 생성 - 쿼리 최적화 및 통계 업데이트 자동화 - VACUUM ANALYZE 자동 실행 ✅ 코드 정리: - 개별 SQL 마이그레이션 파일들을 legacy/ 폴더로 정리 - 중복된 마이그레이션 스크립트 정리 - 깔끔하고 체계적인 프로젝트 구조 완성 ✅ 자동 마이그레이션 시스템 강화: - complete_migrate.py: SQLAlchemy 기반 완전한 마이그레이션 - analyze_and_fix_schema.py: 백엔드 코드 분석 기반 스키마 수정 - fix_missing_tables.py: 누락된 테이블/컬럼 자동 생성 - start.sh: 배포 시 자동 실행 순서 최적화
This commit is contained in:
138
backend/scripts/analyze_and_fix_schema.py
Normal file
138
backend/scripts/analyze_and_fix_schema.py
Normal file
@@ -0,0 +1,138 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
백엔드 코드 전체 분석 후 누락된 모든 컬럼과 테이블을 한 번에 수정하는 스크립트
|
||||
"""
|
||||
|
||||
import os
|
||||
import sys
|
||||
import psycopg2
|
||||
from psycopg2 import sql
|
||||
|
||||
# 현재 디렉토리를 Python 경로에 추가
|
||||
sys.path.insert(0, '/app')
|
||||
|
||||
# 환경 변수 로드
|
||||
DB_HOST = os.getenv("DB_HOST", "postgres")
|
||||
DB_PORT = os.getenv("DB_PORT", "5432")
|
||||
DB_NAME = os.getenv("DB_NAME", "tk_mp_bom")
|
||||
DB_USER = os.getenv("DB_USER", "tkmp_user")
|
||||
DB_PASSWORD = os.getenv("DB_PASSWORD", "tkmp_password_2025")
|
||||
|
||||
def fix_all_missing_columns():
|
||||
"""백엔드 코드 분석 결과를 바탕으로 모든 누락된 컬럼 추가"""
|
||||
print("🔍 백엔드 코드 분석 결과를 바탕으로 모든 누락된 컬럼 수정 시작...")
|
||||
|
||||
try:
|
||||
conn = psycopg2.connect(
|
||||
host=DB_HOST,
|
||||
port=DB_PORT,
|
||||
database=DB_NAME,
|
||||
user=DB_USER,
|
||||
password=DB_PASSWORD
|
||||
)
|
||||
|
||||
with conn.cursor() as cursor:
|
||||
# 1. materials 테이블 누락된 컬럼들
|
||||
print("📝 materials 테이블 컬럼 추가 중...")
|
||||
materials_columns = [
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS brand VARCHAR(100);",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS user_requirement TEXT;",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS purchase_confirmed BOOLEAN DEFAULT FALSE;",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS confirmed_quantity NUMERIC(10,3);",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS purchase_status VARCHAR(20);",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS purchase_confirmed_by VARCHAR(100);",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS purchase_confirmed_at TIMESTAMP;",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS material_hash VARCHAR(64);",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS normalized_description TEXT;",
|
||||
"ALTER TABLE materials ADD COLUMN IF NOT EXISTS revision_status VARCHAR(20);",
|
||||
]
|
||||
|
||||
for sql_cmd in materials_columns:
|
||||
cursor.execute(sql_cmd)
|
||||
print("✅ materials 테이블 컬럼 추가 완료")
|
||||
|
||||
# 2. material_purchase_tracking 테이블 누락된 컬럼들 (백엔드 코드에서 사용됨)
|
||||
print("📝 material_purchase_tracking 테이블 컬럼 추가 중...")
|
||||
mpt_columns = [
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS job_no VARCHAR(50);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS material_hash VARCHAR(64);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS revision VARCHAR(20);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS description TEXT;",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS size_spec VARCHAR(50);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS unit VARCHAR(10);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS bom_quantity NUMERIC(10,3);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS calculated_quantity NUMERIC(10,3);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS supplier_name VARCHAR(100);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS unit_price NUMERIC(12,2);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS total_price NUMERIC(15,2);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS order_date DATE;",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS delivery_date DATE;",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS confirmed_by VARCHAR(100);",
|
||||
"ALTER TABLE material_purchase_tracking ADD COLUMN IF NOT EXISTS confirmed_at TIMESTAMP;",
|
||||
]
|
||||
|
||||
for sql_cmd in mpt_columns:
|
||||
cursor.execute(sql_cmd)
|
||||
print("✅ material_purchase_tracking 테이블 컬럼 추가 완료")
|
||||
|
||||
# 3. files 테이블 누락된 컬럼들
|
||||
print("📝 files 테이블 컬럼 추가 중...")
|
||||
files_columns = [
|
||||
"ALTER TABLE files ADD COLUMN IF NOT EXISTS updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP;",
|
||||
"ALTER TABLE files ADD COLUMN IF NOT EXISTS project_type VARCHAR(50);",
|
||||
]
|
||||
|
||||
for sql_cmd in files_columns:
|
||||
cursor.execute(sql_cmd)
|
||||
print("✅ files 테이블 컬럼 추가 완료")
|
||||
|
||||
# 4. pipe_details 테이블 누락된 컬럼들 (백엔드 코드에서 사용됨)
|
||||
print("📝 pipe_details 테이블 컬럼 추가 중...")
|
||||
pipe_details_columns = [
|
||||
"ALTER TABLE pipe_details ADD COLUMN IF NOT EXISTS material_id INTEGER REFERENCES materials(id);",
|
||||
"ALTER TABLE pipe_details ADD COLUMN IF NOT EXISTS outer_diameter VARCHAR(50);",
|
||||
"ALTER TABLE pipe_details ADD COLUMN IF NOT EXISTS material_spec VARCHAR(100);",
|
||||
"ALTER TABLE pipe_details ADD COLUMN IF NOT EXISTS classification_confidence NUMERIC(3,2);",
|
||||
]
|
||||
|
||||
for sql_cmd in pipe_details_columns:
|
||||
cursor.execute(sql_cmd)
|
||||
print("✅ pipe_details 테이블 컬럼 추가 완료")
|
||||
|
||||
# 5. 기타 누락된 테이블들의 컬럼 추가
|
||||
print("📝 기타 테이블들 컬럼 추가 중...")
|
||||
|
||||
# fitting_details 테이블 컬럼 추가
|
||||
cursor.execute("ALTER TABLE fitting_details ADD COLUMN IF NOT EXISTS main_size VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE fitting_details ADD COLUMN IF NOT EXISTS reduced_size VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE fitting_details ADD COLUMN IF NOT EXISTS length_mm NUMERIC(10,3);")
|
||||
|
||||
# gasket_details 테이블 컬럼 추가
|
||||
cursor.execute("ALTER TABLE gasket_details ADD COLUMN IF NOT EXISTS gasket_subtype VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE gasket_details ADD COLUMN IF NOT EXISTS material_type VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE gasket_details ADD COLUMN IF NOT EXISTS size_inches VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE gasket_details ADD COLUMN IF NOT EXISTS temperature_range VARCHAR(50);")
|
||||
cursor.execute("ALTER TABLE gasket_details ADD COLUMN IF NOT EXISTS fire_safe BOOLEAN DEFAULT FALSE;")
|
||||
|
||||
print("✅ 기타 테이블들 컬럼 추가 완료")
|
||||
|
||||
conn.commit()
|
||||
print("✅ 모든 누락된 컬럼 추가 완료")
|
||||
|
||||
except Exception as e:
|
||||
print(f"❌ 컬럼 추가 실패: {e}")
|
||||
return False
|
||||
finally:
|
||||
if conn:
|
||||
conn.close()
|
||||
|
||||
return True
|
||||
|
||||
if __name__ == "__main__":
|
||||
print("🚀 백엔드 코드 분석 기반 스키마 수정 시작")
|
||||
success = fix_all_missing_columns()
|
||||
if success:
|
||||
print("✅ 모든 스키마 수정 완료")
|
||||
else:
|
||||
print("❌ 스키마 수정 실패")
|
||||
sys.exit(1)
|
||||
Reference in New Issue
Block a user