UNPKG

@athenna/database

Version:

The Athenna database handler for SQL/NoSQL.

63 lines (62 loc) 2.39 kB
/** * @athenna/database * * (c) João Lenon <lenon@athenna.io> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { Is } from '@athenna/common'; import { Database } from '#src/facades/Database'; import { BaseCommand, Argument, Option } from '@athenna/artisan'; export class DbQueryCommand extends BaseCommand { static signature() { return 'db:query'; } static description() { return 'Run a raw SQL query against the database.'; } async handle() { this.logger.simple('({bold,green} [ RUNNING QUERY ])\n'); const sql = this.query.join(' '); const DB = Database.connection(this.connection); try { const result = await DB.raw(sql); if (result === null || result === undefined) { return; } if (Is.Object(result) || Is.Array(result)) { this.logger.simple(JSON.stringify(result)); return; } this.logger.simple(String(result)); } finally { await DB.close(); } } } __decorate([ Argument({ signature: 'query...', description: 'The raw SQL query to execute.' }), __metadata("design:type", Array) ], DbQueryCommand.prototype, "query", void 0); __decorate([ Option({ default: 'default', signature: '-c, --connection <connection>', description: 'Set the the database connection.' }), __metadata("design:type", String) ], DbQueryCommand.prototype, "connection", void 0);