데이터 저장

This commit is contained in:
hyeonsu
2025-09-15 20:07:28 +09:00
parent 6a04ae450d
commit 2c677c2fb8
7 changed files with 636 additions and 253 deletions

View File

@@ -91,34 +91,48 @@ export class EventTriggerService {
const results: ExecutionResult[] = [];
try {
// 해당 테이블과 트리거 타입에 맞는 조건부 연결들 조회
const diagrams = await prisma.dataflow_diagrams.findMany({
where: {
company_code: companyCode,
control: {
path: ["triggerType"],
equals:
triggerType === "insert"
? "insert"
: triggerType === "update"
? ["update", "insert_update"]
: triggerType === "delete"
? "delete"
: triggerType,
},
plan: {
path: ["sourceTable"],
equals: tableName,
},
},
// 🔥 수정: Raw SQL을 사용하여 JSON 배열 검색
const diagrams = (await prisma.$queryRaw`
SELECT * FROM dataflow_diagrams
WHERE company_code = ${companyCode}
AND (
category::text = '"data-save"' OR
category::jsonb ? 'data-save' OR
category::jsonb @> '["data-save"]'
)
`) as any[];
// 각 관계도에서 해당 테이블을 소스로 하는 데이터 저장 관계들 필터링
const matchingDiagrams = diagrams.filter((diagram) => {
// category 배열에서 data-save 연결이 있는지 확인
const categories = diagram.category as any[];
const hasDataSave = Array.isArray(categories)
? categories.some((cat) => cat.category === "data-save")
: false;
if (!hasDataSave) return false;
// plan 배열에서 해당 테이블을 소스로 하는 항목이 있는지 확인
const plans = diagram.plan as any[];
const hasMatchingPlan = Array.isArray(plans)
? plans.some((plan) => plan.sourceTable === tableName)
: false;
// control 배열에서 해당 트리거 타입이 있는지 확인
const controls = diagram.control as any[];
const hasMatchingControl = Array.isArray(controls)
? controls.some((control) => control.triggerType === triggerType)
: false;
return hasDataSave && hasMatchingPlan && hasMatchingControl;
});
logger.info(
`Found ${diagrams.length} conditional connections for table ${tableName} with trigger ${triggerType}`
`Found ${matchingDiagrams.length} matching data-save connections for table ${tableName} with trigger ${triggerType}`
);
// 각 다이어그램에 대해 조건부 연결 실행
for (const diagram of diagrams) {
for (const diagram of matchingDiagrams) {
try {
const result = await this.executeDiagramTrigger(
diagram,