69 lines
2.0 KiB
JavaScript
69 lines
2.0 KiB
JavaScript
import DbClient from ".";
|
|
import _ from "lodash";
|
|
import sqlGenerator from "../../utils/sql-generator";
|
|
export default async function DbUpdate({ table, data, query, targetId, }) {
|
|
try {
|
|
let finalQuery = query || {};
|
|
if (targetId) {
|
|
finalQuery = _.merge(finalQuery, {
|
|
query: {
|
|
id: {
|
|
value: String(targetId),
|
|
},
|
|
},
|
|
});
|
|
}
|
|
const sqlQueryObj = sqlGenerator({
|
|
tableName: table,
|
|
genObject: finalQuery,
|
|
});
|
|
let values = [];
|
|
const whereClause = sqlQueryObj.string.match(/WHERE .*/)?.[0];
|
|
if (whereClause) {
|
|
let sql = `UPDATE ${table} SET`;
|
|
const finalData = {
|
|
...data,
|
|
updated_at: Date.now(),
|
|
};
|
|
const keys = Object.keys(finalData);
|
|
for (let i = 0; i < keys.length; i++) {
|
|
const key = keys[i];
|
|
if (!key)
|
|
continue;
|
|
const isLast = i == keys.length - 1;
|
|
sql += ` ${key}=?`;
|
|
values.push(String(finalData[key]));
|
|
if (!isLast) {
|
|
sql += `,`;
|
|
}
|
|
}
|
|
sql += ` ${whereClause}`;
|
|
values = [...values, ...sqlQueryObj.values];
|
|
const res = DbClient.run(sql, values);
|
|
return {
|
|
success: Boolean(res.changes),
|
|
postInsertReturn: {
|
|
affectedRows: res.changes,
|
|
insertId: Number(res.lastInsertRowid),
|
|
},
|
|
debug: {
|
|
sql,
|
|
values,
|
|
},
|
|
};
|
|
}
|
|
else {
|
|
return {
|
|
success: false,
|
|
msg: `No WHERE clause`,
|
|
};
|
|
}
|
|
}
|
|
catch (error) {
|
|
return {
|
|
success: false,
|
|
error: error.message,
|
|
};
|
|
}
|
|
}
|