dsql-admin/dsql-app/package-shared/functions/dsql/sql/sql-insert-generator.ts

67 lines
1.8 KiB
TypeScript
Raw Normal View History

2024-12-06 13:24:26 +00:00
// @ts-check
2025-01-13 08:00:21 +00:00
interface SQLInsertGenReturn {
query: string;
values: string[];
}
2024-12-06 13:24:26 +00:00
/**
2025-01-13 08:00:21 +00:00
* # SQL Insert Generator
2024-12-06 13:24:26 +00:00
*/
2025-01-13 08:00:21 +00:00
export default function sqlInsertGenerator({
tableName,
data,
}: {
data: any[];
tableName: string;
}): SQLInsertGenReturn | undefined {
2024-12-06 13:24:26 +00:00
try {
if (Array.isArray(data) && data?.[0]) {
/** @type {string[]} */
2025-01-13 08:00:21 +00:00
let insertKeys: string[] = [];
2024-12-06 13:24:26 +00:00
data.forEach((dt) => {
const kys = Object.keys(dt);
kys.forEach((ky) => {
if (!insertKeys.includes(ky)) {
insertKeys.push(ky);
}
});
});
/** @type {string[]} */
2025-01-13 08:00:21 +00:00
let queryBatches: string[] = [];
2024-12-06 13:24:26 +00:00
/** @type {string[]} */
2025-01-13 08:00:21 +00:00
let queryValues: string[] = [];
2024-12-06 13:24:26 +00:00
data.forEach((item) => {
queryBatches.push(
`(${insertKeys
.map((ky) => {
queryValues.push(
item[ky]?.toString()?.match(/./)
? item[ky]
: null
);
return "?";
})
.join(",")})`
);
});
let query = `INSERT INTO ${tableName} (${insertKeys.join(
","
)}) VALUES ${queryBatches.join(",")}`;
return {
query: query,
values: queryValues,
};
} else {
return undefined;
}
2025-01-13 08:00:21 +00:00
} catch (/** @type {any} */ error: any) {
2024-12-06 13:24:26 +00:00
console.log(`SQL insert gen ERROR: ${error.message}`);
return undefined;
}
}