mirror of
https://github.com/swc-project/swc.git
synced 2025-01-03 02:54:43 +03:00
88 lines
2.5 KiB
TypeScript
88 lines
2.5 KiB
TypeScript
|
// Loaded from https://deno.land/x/sql_builder@v1.7.0/util.ts
|
||
|
|
||
|
|
||
|
export function replaceParams(sql: string, params: any | any[]): string {
|
||
|
if (!params) return sql;
|
||
|
let paramIndex = 0;
|
||
|
sql = sql.replace(/('.*')|(".*")|(\?\?)|(\?)/g, (str) => {
|
||
|
if (paramIndex >= params.length) return str;
|
||
|
// ignore
|
||
|
if (/".*"/g.test(str) || /'.*'/g.test(str)) {
|
||
|
return str;
|
||
|
}
|
||
|
// identifier
|
||
|
if (str === "??") {
|
||
|
const val = params[paramIndex++];
|
||
|
if (val instanceof Array) {
|
||
|
return `(${val.map((item) => replaceParams("??", [item])).join(",")})`;
|
||
|
} else if (val === "*") {
|
||
|
return val;
|
||
|
} else if (typeof val === "string" && val.includes(".")) {
|
||
|
// a.b => `a`.`b`
|
||
|
const _arr = val.split(".");
|
||
|
return replaceParams(_arr.map(() => "??").join("."), _arr);
|
||
|
} else if (
|
||
|
typeof val === "string" &&
|
||
|
(val.includes(" as ") || val.includes(" AS "))
|
||
|
) {
|
||
|
// a as b => `a` AS `b`
|
||
|
const newVal = val.replace(" as ", " AS ");
|
||
|
const _arr = newVal.split(" AS ");
|
||
|
return replaceParams(_arr.map(() => "??").join(" AS "), _arr);
|
||
|
} else {
|
||
|
return ["`", val, "`"].join("");
|
||
|
}
|
||
|
}
|
||
|
// value
|
||
|
const val = params[paramIndex++];
|
||
|
if (val === null) return "NULL";
|
||
|
switch (typeof val) {
|
||
|
case "object":
|
||
|
if (val instanceof Date) return `"${formatDate(val)}"`;
|
||
|
if (val instanceof Array) {
|
||
|
return `(${val.map((item) => replaceParams("?", [item])).join(",")})`;
|
||
|
}
|
||
|
case "string":
|
||
|
return `"${escapeString(val)}"`;
|
||
|
case "undefined":
|
||
|
return "NULL";
|
||
|
case "number":
|
||
|
case "boolean":
|
||
|
default:
|
||
|
return val;
|
||
|
}
|
||
|
});
|
||
|
return sql;
|
||
|
}
|
||
|
|
||
|
function formatDate(date: Date) {
|
||
|
const year = date.getFullYear();
|
||
|
const month = (date.getMonth() + 1).toString().padStart(2, "0");
|
||
|
const days = date
|
||
|
.getDate()
|
||
|
.toString()
|
||
|
.padStart(2, "0");
|
||
|
const hours = date
|
||
|
.getHours()
|
||
|
.toString()
|
||
|
.padStart(2, "0");
|
||
|
const minutes = date
|
||
|
.getMinutes()
|
||
|
.toString()
|
||
|
.padStart(2, "0");
|
||
|
const seconds = date
|
||
|
.getSeconds()
|
||
|
.toString()
|
||
|
.padStart(2, "0");
|
||
|
// Date does not support microseconds precision, so we only keep the milliseconds part.
|
||
|
const milliseconds = date
|
||
|
.getMilliseconds()
|
||
|
.toString()
|
||
|
.padStart(3, "0");
|
||
|
return `${year}-${month}-${days} ${hours}:${minutes}:${seconds}.${milliseconds}`;
|
||
|
}
|
||
|
|
||
|
function escapeString(str: string) {
|
||
|
return str.replaceAll("\\", "\\\\").replaceAll('"', '\\"');
|
||
|
}
|