- 삭제된 DB 테이블들과 관련 코드 정리: * 12개 사용하지 않는 테이블 삭제 (activity_logs, CuttingPlan, DailyIssueReports 등) * 관련 모델, 컨트롤러, 라우트 파일들 삭제 * index.js에서 삭제된 라우트들 제거 - 웹 UI 페이지 정리: * 21개 사용하지 않는 페이지 삭제 * issue-reports 폴더 전체 삭제 * 모든 사용자 권한을 그룹장 대시보드로 통일 - 데이터베이스 스키마 정리: * v1 스키마로 통일 (daily_work_reports 테이블) * JSON 데이터 임포트 스크립트 구현 * 외래키 관계 정리 및 데이터 일관성 확보 - 통합 Docker Compose 설정: * 모든 서비스를 단일 docker-compose.yml로 통합 * 20000번대 포트 유지 * JWT 시크릿 및 환경변수 설정 - 문서화: * DATABASE_SCHEMA.md: 현재 DB 스키마 문서화 * DELETED_TABLES.md: 삭제된 테이블 목록 * DELETED_PAGES.md: 삭제된 페이지 목록
89 lines
2.1 KiB
JavaScript
89 lines
2.1 KiB
JavaScript
const { getDb } = require('../dbPool');
|
|
|
|
// 1. 작업자 생성
|
|
const create = async (worker, callback) => {
|
|
try {
|
|
const db = await getDb();
|
|
const { worker_name, join_date, job_type, salary, annual_leave, status } = worker;
|
|
|
|
const [result] = await db.query(
|
|
`INSERT INTO workers
|
|
(worker_name, join_date, job_type, salary, annual_leave, status)
|
|
VALUES (?, ?, ?, ?, ?, ?)`,
|
|
[worker_name, join_date, job_type, salary, annual_leave, status]
|
|
);
|
|
|
|
callback(null, result.insertId);
|
|
} catch (err) {
|
|
callback(err);
|
|
}
|
|
};
|
|
|
|
// 2. 전체 조회
|
|
const getAll = async (callback) => {
|
|
try {
|
|
const db = await getDb();
|
|
const [rows] = await db.query(`SELECT * FROM workers ORDER BY worker_id DESC`);
|
|
callback(null, rows);
|
|
} catch (err) {
|
|
callback(err);
|
|
}
|
|
};
|
|
|
|
// 3. 단일 조회
|
|
const getById = async (worker_id, callback) => {
|
|
try {
|
|
const db = await getDb();
|
|
const [rows] = await db.query(`SELECT * FROM workers WHERE worker_id = ?`, [worker_id]);
|
|
callback(null, rows[0]);
|
|
} catch (err) {
|
|
callback(err);
|
|
}
|
|
};
|
|
|
|
// 4. 작업자 수정
|
|
const update = async (worker, callback) => {
|
|
try {
|
|
const db = await getDb();
|
|
const { worker_id, worker_name, join_date, job_type, salary, annual_leave, status } = worker;
|
|
|
|
const [result] = await db.query(
|
|
`UPDATE workers
|
|
SET worker_name = ?,
|
|
join_date = ?,
|
|
job_type = ?,
|
|
salary = ?,
|
|
annual_leave = ?,
|
|
status = ?
|
|
WHERE worker_id = ?`,
|
|
[worker_name, join_date, job_type, salary, annual_leave, status, worker_id]
|
|
);
|
|
|
|
callback(null, result.affectedRows);
|
|
} catch (err) {
|
|
callback(new Error(err.message || String(err)));
|
|
}
|
|
};
|
|
|
|
// 5. 삭제
|
|
const remove = async (worker_id, callback) => {
|
|
try {
|
|
const db = await getDb();
|
|
const [result] = await db.query(
|
|
`DELETE FROM workers WHERE worker_id = ?`,
|
|
[worker_id]
|
|
);
|
|
callback(null, result.affectedRows);
|
|
} catch (err) {
|
|
callback(err);
|
|
}
|
|
};
|
|
|
|
// ✅ 모듈 내보내기 (정상 구조)
|
|
module.exports = {
|
|
create,
|
|
getAll,
|
|
getById,
|
|
update,
|
|
remove
|
|
}; |