- 모델 파일들의 데이터베이스 연결 및 쿼리 최적화 - 마이그레이션 파일 정리 및 통합 - Docker 설정 파일 추가 - 프로젝트 시작/중지 스크립트 추가 - README 및 문서 업데이트
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
|
|
}; |