69 lines
2.6 KiB
Python
69 lines
2.6 KiB
Python
# -*- coding: utf-8 -*-
|
|
"""APC 매칭 성능 측정"""
|
|
import sys, io, time
|
|
sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
|
|
sys.path.insert(0, 'c:\\Users\\청춘약국\\source\\pharmacy-pos-qr-system\\backend')
|
|
|
|
from db.dbsetup import get_db_session
|
|
from sqlalchemy import text, create_engine
|
|
|
|
print('=== APC 매칭 성능 측정 ===\n')
|
|
|
|
# 1. MSSQL: 동물약 + APC 조회
|
|
start = time.time()
|
|
session = get_db_session('PM_DRUG')
|
|
result = session.execute(text("""
|
|
SELECT G.DrugCode, G.GoodsName,
|
|
(SELECT TOP 1 U.CD_CD_BARCODE FROM CD_ITEM_UNIT_MEMBER U
|
|
WHERE U.DRUGCODE = G.DrugCode AND U.CD_CD_BARCODE LIKE '023%') AS APC_CODE
|
|
FROM CD_GOODS G
|
|
WHERE G.POS_BOON = '010103' AND G.GoodsSelCode = 'B'
|
|
"""))
|
|
mssql_rows = list(result)
|
|
no_apc = [r for r in mssql_rows if not r.APC_CODE]
|
|
has_apc = [r for r in mssql_rows if r.APC_CODE]
|
|
mssql_time = time.time() - start
|
|
print(f'1. MSSQL 동물약 조회: {mssql_time:.3f}초')
|
|
print(f' - 총 제품: {len(mssql_rows)}개')
|
|
print(f' - APC 있음: {len(has_apc)}개 ✅')
|
|
print(f' - APC 없음: {len(no_apc)}개 ❌')
|
|
|
|
# 2. PostgreSQL 연결 + 매칭 검색
|
|
pg = create_engine('postgresql://admin:trajet6640@192.168.0.87:5432/apdb_master').connect()
|
|
|
|
# 샘플 매칭 테스트
|
|
sample_count = min(5, len(no_apc))
|
|
start = time.time()
|
|
match_count = 0
|
|
for drug in no_apc[:sample_count]:
|
|
search_name = drug.GoodsName.replace('(판)', '').split('(')[0].strip()
|
|
res = pg.execute(text("""
|
|
SELECT apc, product_name FROM apc
|
|
WHERE product_name ILIKE :p LIMIT 5
|
|
"""), {'p': f'%{search_name}%'})
|
|
if list(res):
|
|
match_count += 1
|
|
pg_search_time = time.time() - start
|
|
per_search = pg_search_time / sample_count if sample_count > 0 else 0
|
|
print(f'\n2. PostgreSQL 매칭 검색: {pg_search_time:.3f}초 ({sample_count}개 샘플)')
|
|
print(f' - 건당 소요: {per_search*1000:.1f}ms')
|
|
print(f' - 매칭 성공: {match_count}/{sample_count}')
|
|
print(f' - 예상 전체: {per_search * len(no_apc):.1f}초 ({len(no_apc)}개)')
|
|
|
|
# 3. APC 테이블 통계
|
|
start = time.time()
|
|
total_apc = pg.execute(text("SELECT COUNT(*) FROM apc")).scalar()
|
|
with_image = pg.execute(text("SELECT COUNT(*) FROM apc WHERE image_url1 IS NOT NULL AND image_url1 != ''")).scalar()
|
|
pg.close()
|
|
print(f'\n3. APDB 통계:')
|
|
print(f' - 전체 APC: {total_apc:,}개')
|
|
print(f' - 이미지 있음: {with_image:,}개 ({with_image/total_apc*100:.1f}%)')
|
|
|
|
# 4. CD_ITEM_UNIT_MEMBER 구조 확인
|
|
print(f'\n4. 현재 APC 매핑 상태:')
|
|
for r in has_apc[:5]:
|
|
print(f' ✅ {r.GoodsName[:25]:<25} → {r.APC_CODE}')
|
|
|
|
session.close()
|
|
print('\n=== 측정 완료 ===')
|