UNPKG

innomize-typeorm

Version:

Data-Mapper ORM for TypeScript, ES7, ES6, ES5. Supports MySQL, PostgreSQL, MariaDB, SQLite, MS SQL Server, Oracle, MongoDB databases.

404 lines (402 loc) 18.4 kB
import * as tslib_1 from "tslib"; import { Query } from "../driver/Query"; import { SqlInMemory } from "../driver/SqlInMemory"; import { PromiseUtils } from "../util/PromiseUtils"; var BaseQueryRunner = /** @class */ (function () { function BaseQueryRunner() { // ------------------------------------------------------------------------- // Public Properties // ------------------------------------------------------------------------- /** * Indicates if connection for this query runner is released. * Once its released, query runner cannot run queries anymore. */ this.isReleased = false; /** * Indicates if transaction is in progress. */ this.isTransactionActive = false; /** * Stores temporarily user data. * Useful for sharing data with subscribers. */ this.data = {}; /** * All synchronized tables in the database. */ this.loadedTables = []; /** * All synchronized views in the database. */ this.loadedViews = []; /** * Indicates if special query runner mode in which sql queries won't be executed is enabled. */ this.sqlMemoryMode = false; /** * Sql-s stored if "sql in memory" mode is enabled. */ this.sqlInMemory = new SqlInMemory(); } // ------------------------------------------------------------------------- // Public Methods // ------------------------------------------------------------------------- /** * Loads given table's data from the database. */ BaseQueryRunner.prototype.getTable = function (tablePath) { return tslib_1.__awaiter(this, void 0, void 0, function () { var _a; return tslib_1.__generator(this, function (_b) { switch (_b.label) { case 0: _a = this; return [4 /*yield*/, this.loadTables([tablePath])]; case 1: _a.loadedTables = _b.sent(); return [2 /*return*/, this.loadedTables.length > 0 ? this.loadedTables[0] : undefined]; } }); }); }; /** * Loads all tables (with given names) from the database. */ BaseQueryRunner.prototype.getTables = function (tableNames) { return tslib_1.__awaiter(this, void 0, void 0, function () { var _a; return tslib_1.__generator(this, function (_b) { switch (_b.label) { case 0: _a = this; return [4 /*yield*/, this.loadTables(tableNames)]; case 1: _a.loadedTables = _b.sent(); return [2 /*return*/, this.loadedTables]; } }); }); }; /** * Loads given view's data from the database. */ BaseQueryRunner.prototype.getView = function (viewPath) { return tslib_1.__awaiter(this, void 0, void 0, function () { var _a; return tslib_1.__generator(this, function (_b) { switch (_b.label) { case 0: _a = this; return [4 /*yield*/, this.loadViews([viewPath])]; case 1: _a.loadedViews = _b.sent(); return [2 /*return*/, this.loadedViews.length > 0 ? this.loadedViews[0] : undefined]; } }); }); }; /** * Loads given view's data from the database. */ BaseQueryRunner.prototype.getViews = function (viewPaths) { return tslib_1.__awaiter(this, void 0, void 0, function () { var _a; return tslib_1.__generator(this, function (_b) { switch (_b.label) { case 0: _a = this; return [4 /*yield*/, this.loadViews(viewPaths)]; case 1: _a.loadedViews = _b.sent(); return [2 /*return*/, this.loadedViews]; } }); }); }; /** * Enables special query runner mode in which sql queries won't be executed, * instead they will be memorized into a special variable inside query runner. * You can get memorized sql using getMemorySql() method. */ BaseQueryRunner.prototype.enableSqlMemory = function () { this.sqlInMemory = new SqlInMemory(); this.sqlMemoryMode = true; }; /** * Disables special query runner mode in which sql queries won't be executed * started by calling enableSqlMemory() method. * * Previously memorized sql will be flushed. */ BaseQueryRunner.prototype.disableSqlMemory = function () { this.sqlInMemory = new SqlInMemory(); this.sqlMemoryMode = false; }; /** * Flushes all memorized sqls. */ BaseQueryRunner.prototype.clearSqlMemory = function () { this.sqlInMemory = new SqlInMemory(); }; /** * Gets sql stored in the memory. Parameters in the sql are already replaced. */ BaseQueryRunner.prototype.getMemorySql = function () { return this.sqlInMemory; }; /** * Executes up sql queries. */ BaseQueryRunner.prototype.executeMemoryUpSql = function () { return tslib_1.__awaiter(this, void 0, void 0, function () { var _this = this; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, PromiseUtils.runInSequence(this.sqlInMemory.upQueries, function (upQuery) { return _this.query(upQuery.query, upQuery.parameters); })]; case 1: _a.sent(); return [2 /*return*/]; } }); }); }; /** * Executes down sql queries. */ BaseQueryRunner.prototype.executeMemoryDownSql = function () { return tslib_1.__awaiter(this, void 0, void 0, function () { var _this = this; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: return [4 /*yield*/, PromiseUtils.runInSequence(this.sqlInMemory.downQueries.reverse(), function (downQuery) { return _this.query(downQuery.query, downQuery.parameters); })]; case 1: _a.sent(); return [2 /*return*/]; } }); }); }; // ------------------------------------------------------------------------- // Protected Methods // ------------------------------------------------------------------------- /** * Gets view from previously loaded views, otherwise loads it from database. */ BaseQueryRunner.prototype.getCachedView = function (viewName) { return tslib_1.__awaiter(this, void 0, void 0, function () { var view, foundViews; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: view = this.loadedViews.find(function (view) { return view.name === viewName; }); if (view) return [2 /*return*/, view]; return [4 /*yield*/, this.loadViews([viewName])]; case 1: foundViews = _a.sent(); if (foundViews.length > 0) { this.loadedViews.push(foundViews[0]); return [2 /*return*/, foundViews[0]]; } else { throw new Error("View \"" + viewName + "\" does not exist."); } return [2 /*return*/]; } }); }); }; /** * Gets table from previously loaded tables, otherwise loads it from database. */ BaseQueryRunner.prototype.getCachedTable = function (tableName) { return tslib_1.__awaiter(this, void 0, void 0, function () { var table, foundTables; return tslib_1.__generator(this, function (_a) { switch (_a.label) { case 0: table = this.loadedTables.find(function (table) { return table.name === tableName; }); if (table) return [2 /*return*/, table]; return [4 /*yield*/, this.loadTables([tableName])]; case 1: foundTables = _a.sent(); if (foundTables.length > 0) { this.loadedTables.push(foundTables[0]); return [2 /*return*/, foundTables[0]]; } else { throw new Error("Table \"" + tableName + "\" does not exist."); } return [2 /*return*/]; } }); }); }; /** * Replaces loaded table with given changed table. */ BaseQueryRunner.prototype.replaceCachedTable = function (table, changedTable) { var foundTable = this.loadedTables.find(function (loadedTable) { return loadedTable.name === table.name; }); if (foundTable) { foundTable.name = changedTable.name; foundTable.columns = changedTable.columns; foundTable.indices = changedTable.indices; foundTable.foreignKeys = changedTable.foreignKeys; foundTable.uniques = changedTable.uniques; foundTable.checks = changedTable.checks; foundTable.justCreated = changedTable.justCreated; foundTable.engine = changedTable.engine; } }; BaseQueryRunner.prototype.getTypeormMetadataTableName = function () { var options = this.connection.driver.options; return this.connection.driver.buildTableName("typeorm_metadata", options.schema, options.database); }; /** * Checks if at least one of column properties was changed. * Does not checks column type, length and autoincrement, because these properties changes separately. */ BaseQueryRunner.prototype.isColumnChanged = function (oldColumn, newColumn, checkDefault, checkComment) { // this logs need to debug issues in column change detection. Do not delete it! // console.log("charset ---------------"); // console.log(oldColumn.charset !== newColumn.charset); // console.log(oldColumn.charset, newColumn.charset); // console.log("collation ---------------"); // console.log(oldColumn.collation !== newColumn.collation); // console.log(oldColumn.collation, newColumn.collation); // console.log("precision ---------------"); // console.log(oldColumn.precision !== newColumn.precision); // console.log(oldColumn.precision, newColumn.precision); // console.log("scale ---------------"); // console.log(oldColumn.scale !== newColumn.scale); // console.log(oldColumn.scale, newColumn.scale); // console.log("default ---------------"); // console.log((checkDefault && oldColumn.default !== newColumn.default)); // console.log(oldColumn.default, newColumn.default); // console.log("isNullable ---------------"); // console.log(oldColumn.isNullable !== newColumn.isNullable); // console.log(oldColumn.isNullable, newColumn.isNullable); // console.log("comment ---------------"); // console.log((checkComment && oldColumn.comment !== newColumn.comment)); // console.log(oldColumn.comment, newColumn.comment); // console.log("enum ---------------"); // console.log(oldColumn.enum !== newColumn.enum); // console.log(oldColumn.enum, newColumn.enum); return oldColumn.charset !== newColumn.charset || oldColumn.collation !== newColumn.collation || oldColumn.precision !== newColumn.precision || oldColumn.scale !== newColumn.scale || oldColumn.width !== newColumn.width // MySQL only || oldColumn.zerofill !== newColumn.zerofill // MySQL only || oldColumn.unsigned !== newColumn.unsigned // MySQL only || oldColumn.asExpression !== newColumn.asExpression // MySQL only || (checkDefault && oldColumn.default !== newColumn.default) || oldColumn.onUpdate !== newColumn.onUpdate // MySQL only || oldColumn.isNullable !== newColumn.isNullable || (checkComment && oldColumn.comment !== newColumn.comment) || oldColumn.enum !== newColumn.enum; }; /** * Checks if column length is by default. */ BaseQueryRunner.prototype.isDefaultColumnLength = function (table, column, length) { // if table have metadata, we check if length is specified in column metadata if (this.connection.hasMetadata(table.name)) { var metadata = this.connection.getMetadata(table.name); var columnMetadata = metadata.findColumnWithDatabaseName(column.name); if (columnMetadata && columnMetadata.length) return false; } if (this.connection.driver.dataTypeDefaults && this.connection.driver.dataTypeDefaults[column.type] && this.connection.driver.dataTypeDefaults[column.type].length) { return this.connection.driver.dataTypeDefaults[column.type].length.toString() === length.toString(); } return false; }; /** * Checks if column display width is by default. Used only for MySQL. */ BaseQueryRunner.prototype.isDefaultColumnWidth = function (table, column, width) { // if table have metadata, we check if length is specified in column metadata if (this.connection.hasMetadata(table.name)) { var metadata = this.connection.getMetadata(table.name); var columnMetadata = metadata.findColumnWithDatabaseName(column.name); if (columnMetadata && columnMetadata.width) return false; } if (this.connection.driver.dataTypeDefaults && this.connection.driver.dataTypeDefaults[column.type] && this.connection.driver.dataTypeDefaults[column.type].width) { return this.connection.driver.dataTypeDefaults[column.type].width === width; } return false; }; /** * Checks if column precision is by default. */ BaseQueryRunner.prototype.isDefaultColumnPrecision = function (table, column, precision) { // if table have metadata, we check if length is specified in column metadata if (this.connection.hasMetadata(table.name)) { var metadata = this.connection.getMetadata(table.name); var columnMetadata = metadata.findColumnWithDatabaseName(column.name); if (columnMetadata && columnMetadata.precision !== null && columnMetadata.precision !== undefined) return false; } if (this.connection.driver.dataTypeDefaults && this.connection.driver.dataTypeDefaults[column.type] && this.connection.driver.dataTypeDefaults[column.type].precision !== null && this.connection.driver.dataTypeDefaults[column.type].precision !== undefined) return this.connection.driver.dataTypeDefaults[column.type].precision === precision; return false; }; /** * Checks if column scale is by default. */ BaseQueryRunner.prototype.isDefaultColumnScale = function (table, column, scale) { // if table have metadata, we check if length is specified in column metadata if (this.connection.hasMetadata(table.name)) { var metadata = this.connection.getMetadata(table.name); var columnMetadata = metadata.findColumnWithDatabaseName(column.name); if (columnMetadata && columnMetadata.scale !== null && columnMetadata.scale !== undefined) return false; } if (this.connection.driver.dataTypeDefaults && this.connection.driver.dataTypeDefaults[column.type] && this.connection.driver.dataTypeDefaults[column.type].scale !== null && this.connection.driver.dataTypeDefaults[column.type].scale !== undefined) return this.connection.driver.dataTypeDefaults[column.type].scale === scale; return false; }; /** * Executes sql used special for schema build. */ BaseQueryRunner.prototype.executeQueries = function (upQueries, downQueries) { return tslib_1.__awaiter(this, void 0, void 0, function () { var _a, _b; var _this = this; return tslib_1.__generator(this, function (_c) { switch (_c.label) { case 0: if (upQueries instanceof Query) upQueries = [upQueries]; if (downQueries instanceof Query) downQueries = [downQueries]; (_a = this.sqlInMemory.upQueries).push.apply(_a, tslib_1.__spread(upQueries)); (_b = this.sqlInMemory.downQueries).push.apply(_b, tslib_1.__spread(downQueries)); // if sql-in-memory mode is enabled then simply store sql in memory and return if (this.sqlMemoryMode === true) return [2 /*return*/, Promise.resolve()]; return [4 /*yield*/, PromiseUtils.runInSequence(upQueries, function (upQuery) { return _this.query(upQuery.query, upQuery.parameters); })]; case 1: _c.sent(); return [2 /*return*/]; } }); }); }; return BaseQueryRunner; }()); export { BaseQueryRunner }; //# sourceMappingURL=BaseQueryRunner.js.map