UNPKG

@jakub.knejzlik/ts-query

Version:

TypeScript implementation of SQL builder

36 lines (35 loc) 1.4 kB
"use strict"; 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;