@jakub.knejzlik/ts-query
Version:
TypeScript implementation of SQL builder
36 lines (35 loc) • 1.4 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.SQLiteFlavor = void 0;
const Expression_1 = require("../Expression");
const mysql_1 = require("./mysql");
class SQLiteFlavor extends mysql_1.MySQLFlavor {
constructor() {
super(...arguments);
// protected columnQuotes: string = "'"
this.stringQuotes = "'";
}
escapeFunction(fn) {
const args = fn.value.map((arg) => Expression_1.ExpressionBase.deserialize(arg).toSQL(this));
if (fn.name === "MONTH") {
return `strftime('%m', ${args.join(", ")}, 'localtime')`;
}
if (fn.name === "YEAR") {
return `strftime('%Y', ${args.join(", ")}, 'localtime')`;
}
if (fn.name === "IF") {
return `IIF(${args.join(", ")})`;
}
if (fn.name === "DATEADD") {
const argsValues = fn.value.map((x) => Expression_1.ExpressionBase.deserializeValue(x));
return `DateTime(${args[0]}, '${parseInt(argsValues[1].value.toString(), 10) >= 0
? "+" + argsValues[1].value.toString()
: argsValues[1].value.toString()} ${argsValues[2].value.toString()}')`;
}
return super.escapeFunction(fn);
}
escapeTable(table) {
return super.escapeTable(table.substring(table.indexOf("@") + 1));
}
}
exports.SQLiteFlavor = SQLiteFlavor;
;