@jakub.knejzlik/ts-query
Version:
TypeScript implementation of SQL builder
34 lines (33 loc) • 1.22 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.AWSTimestreamFlavor = void 0;
const Expression_1 = require("../Expression");
const default_1 = require("./default");
class AWSTimestreamFlavor extends default_1.DefaultFlavor {
constructor() {
super(...arguments);
this.columnQuotes = `"`;
this.stringQuotes = `'`;
}
escapeLimitAndOffset(limit, offset) {
let str = "";
if (offset !== undefined) {
str += ` OFFSET ${offset}`;
}
if (limit !== undefined) {
str += ` LIMIT ${limit}`;
}
return str;
}
escapeFunction(fn) {
const args = fn.value.map((arg) => Expression_1.ExpressionBase.deserialize(arg).toSQL(this));
if (fn.name === "DATEADD") {
const argsValues = fn.value.map((x) => Expression_1.ExpressionBase.deserializeValue(x));
const interval = argsValues[1].value.toString();
const intervalType = argsValues[2].value.toString();
return `date_add('${intervalType}', ${interval}, ${args[0]})`;
}
return super.escapeFunction(fn);
}
}
exports.AWSTimestreamFlavor = AWSTimestreamFlavor;
;