UNPKG

@jakub.knejzlik/ts-query

Version:

TypeScript implementation of SQL builder

34 lines (33 loc) 1.22 kB
"use strict"; 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;