SQL整形ツールを作成した

2020-09-30
mysqloraclepostgresqlvue.jsnuxt.js
    

目次

概要

SQL整形ツールを作成しました。

URLはこちらです。

SQL 整形ツール - うぇぶでゔツール

sql pretty

特徴

  • フロントのみで完結するサービスなのでサーバにソースを送ったりすることはありません。
  • シンタックスハイライト機能
  • アッパーケース対応
  • インデント変更可能
  • リアルタイム変換
  • その他、各種機能追加の検討中

使い方

例えば次のような入力値が

select * 
from foo_table foo 
where foo.id > 100 order by foo.name;

このように変換されます。

SELECT
  *
FROM
  foo_table foo
WHERE
  foo.id > 100
ORDER BY
  foo.name;

インデントは2スペース、4スペース、タブを選択することができます。

FW/ライブラリ等

nuxt

ページの作成にvue nuxtを利用しています。

sql-formatter-plus

SQLの整形に sql-formatter-plus を使っています。

SQL Formatter Plus

Monaco Editor

エディタ部分の実装はMonacoEditorを利用しています。

Monaco Editor

おまけ

ソース

サンプルコードです。

<template>
  <div>
    <v-row no-gutters>
      <v-col sm="6">
        <h3>Input</h3>
        <div class="monacoCover">
          <MonacoEditor
            ref="srcEditor"
            v-model="srcCode"
            :language="language"
            :diffEditor="false"
            :theme="dark ? 'vs-dark' : 'default'"
            :style="{ width: clientWidth, height: clientHeight }"
            :readOnly="true"
            :options="{
              scrollBeyondLastLine: true,
              wordWrap: 'on',
              fontSize: fontSize,
              enableSplitViewResizing: false,
              ignoreTrimWhitespace: false,
            }"
            @editorWillMount="onSrcEditorWillMount"
          />
        </div>
      </v-col>
      <v-col sm="6">
        <h3>Output</h3>
        <div class="monacoCover">
          <MonacoEditor
            ref="dstEditor"
            v-model="dstCode"
            :language="language"
            :theme="dark ? 'vs-dark' : 'default'"
            :style="{ width: clientWidth, height: clientHeight }"
            :readOnly="true"
            :options="{
              scrollBeyondLastLine: true,
              wordWrap: 'on',
              fontSize: fontSize,
              enableSplitViewResizing: false,
              ignoreTrimWhitespace: false,
            }"
            @editorWillMount="onDstEditorWillMount"
          />
        </div>
      </v-col>
    </v-row>
    <h3>Option</h3>
    <v-row style="height: 35px">
      <v-col>Indent</v-col>
      <v-col>
        <v-radio-group v-model="formatOpt.indent" row>
          <v-radio label="2 spaces" value="0"></v-radio>
          <v-radio label="4 spaces" value="1"></v-radio>
          <v-radio label="tab" value="2"></v-radio>
        </v-radio-group>
      </v-col>
    </v-row>
    <v-row style="height: 35px">
      <v-col>Uppercase</v-col>
      <v-col>
        <v-checkbox
          v-model="formatOpt.uppercase"
          label="Uppercase"
          hide-details
        ></v-checkbox>
      </v-col>
    </v-row>
  </div>
</template>

<script>
import MonacoEditor from "vue-monaco";
import SqlFormatter from "sql-formatter-plus";

export default {
  components: { MonacoEditor },
  data: () => ({
    srcCode:
      "select * from foo_table foo where foo.id > 100 order by foo.name;",
    srcMonaco: null,
    dstMonaco: null,
    language: "sql",
    dark: false,
    fontSize: 12,
    clientWidth: "99%",
    clientHeight: "300px",
    formatOpt: {
      indent: "0",
      uppercase: true,
    },
  }),
  methods: {
    onSrcEditorWillMount(monaco) {
      this.srcMonaco = monaco;
    },
    onDstEditorWillMount(monaco) {
      this.dstMonaco = monaco;
    },
    resize(el) {
      this.$refs.srcEditor.getEditor().layout();
      this.$refs.dstEditor.getEditor().layout();
    },
  },
  mounted() {
    window.addEventListener("resize", this.resize);
  },
  destroyed() {
    window.removeEventListener("resize", this.resize);
  },
  computed: {
    dstCode: function () {
      const indentType = ["  ", "    ", "\t"];
      try {
        return SqlFormatter.format(this.srcCode, {
          language: "sql",
          indent: indentType[Number(this.formatOpt.indent)],
          uppercase: this.formatOpt.uppercase,
          linesBetweenQueries: 2,
        });
      } catch (e) {
        return "";
      }
    },
  },
};
</script>

<style scoped>
.monacoCover {
  background-color: #9f9f9f;
  padding: 1px;
}
</style>
    
s-yoshiki
s-yoshiki
githubtwitterqiita
Web作ってますが、インタラクティブなプログラミングも好きです。
JavaScript / Vue / node.js / PHP / AWS / OpenCV

関連記事

DBクライアントツールはDBeaverをおすすめしたい
DBeaver について 特徴 対応DB 対応OS 利用環境 アーカイブ インストール windows mac Linux コネクションの作成 SQLを実行する その他 CloudBeaverについて 今までいくつかのDB…

CentOS8 に Oracle12.2 clientをインストールする
実施した環境 セットアップ clientツールの 準備 インストール 環境変数にパスを通す 実行 libnsl.so.1: cannot open shared object file と表示される場合 CentOS8 に Oracle12.2 client…

MySQL8.0 で利用できるパラメータを表示する方法
オプションの表示 mysql8.0でmy.cnfなどで利用できるパラメータ一覧を出す方法。 オプションの表示 オプションの表示は次のコマンドで実施できます mysqld — The MySQL Server 【MySQLパラメーター比較資料】MySQL 5.…

CentOS に MySQL8.0をインストールする
はじめに 環境 起動 MySQLインストール my.cnf の設定 プロセス立ち上げ エラー The designated data directory /var/lib/mysql/ is unusable. You can remove all files…

Vue.jsで作成された、ちょっと面白くて役立ちそうなサービス
UIコンポーネント VueSocial CKEditor 5 Vue.Draggable Vuetable 2 vuejs-datepicker Kalendar Vue Apexcharts Vue.js Google Charts vue-cart WebIDE…

WordPressのDBから記事データを抽出する
WordPressのDB関連図 公開記事一覧の取得 タグ・カテゴリの取得 サムネイルの取得 おまけ: PHPスクリプト化しました 参考にしたところ WordPressにため込んだデータMarkdown化しGatsby…

Firebase + Nuxt で認証付きページを作るときに参考にしたいところ
Webアプリケーションのセッション管理にJWT導入を検討する際の考え方 Service Worker によるセッション管理 ユーザー セッションの管理 Nuxt.jsとFirebaseでSPA×SSR×PWA×サーバーレスを実現する CookieとセッションとJWT SSR…

Macでも利用できるDBクライアント MySQL PostgreSQL Oracle など
デスクトップ系ツール TablePlus DBeaver MySQL Workbench Sequel pro Webアプリケーション phpMyAdmin Adminer 参考 Macで利用できるDB (MySQL PostgreSQL Oracle…

DockerでMySQL5.1.73を利用する。docker-composeから起動
Dockerのインストールから実行まで docker-compose から起動 詳細 Docker から MySQL 5.1.73 を利用する。 Dockerのインストールから実行まで docker imageの pull。 119MB…

phpMyAdminをDockerで起動する設定
docker-compose の設定 phpMyAdminのコンテナイメージ GitHub phpMyAdminはPHPで実装されているMySQLの管理ツールです。サーバに配置しブラウザから操作するのが特徴です。このphpMyAdminをdocker…

最新の投稿

Python poetryでパッケージ開発 PyPIで公開 Pytestでテスト CIをGitHub Actionsで回す
Poetry でパッケージ開発 pytest でユニットテストを実施しカバレッジを算出する パッケージをビルドし PyPI で公開する 検証環境にデプロイする 本番環境にデプロイする GitHub Actions で CI を回す codecovの設定 GitHub…

Perlでconstant(定数)をhashのキーに使う
ハマった事象 解決方法 1 括弧をつける 2 & をつける 参考にしたサイト Perlでconstant(定数)をhash…

php-fpmのステータスページを表示 Apache & htaccess
試した環境 php-fpm の pm.status_path について php-fpmのconfの設定 .htaccess の設定 アクセスしてみる 参考にしたサイト Apache環境で php-fpm のステータスページを htaccess…

DBクライアントツールはDBeaverをおすすめしたい
DBeaver について 特徴 対応DB 対応OS 利用環境 アーカイブ インストール windows mac Linux コネクションの作成 SQLを実行する その他 CloudBeaverについて 今までいくつかのDB…

CentOS8 に Oracle12.2 clientをインストールする
実施した環境 セットアップ clientツールの 準備 インストール 環境変数にパスを通す 実行 libnsl.so.1: cannot open shared object file と表示される場合 CentOS8 に Oracle12.2 client…

フェールセーフやフェールソフト・フールプルーフ 障害対策用語の整理

JSで32ビット符号付き整数に対してのビット演算でハマった
具体例 参考にしたサイト JSでサブネットマスクの計算を行おうとしたとき、ビット演算でハマりました。その時のメモです。 JSでサブネットマスクの計算 JSでビット演算子を利用する場合 3…

Gitにプロキシを設定する
プロキシを設定する 確認 Gitでプロキシを通しておくメモです。 プロキシを設定する 以下のコマンドでproxyを通します。 ※ がプロキシのURL…

JSでIPアドレスがサブネットマスクで指定した範囲内にあるか判定する
IPアドレスが指定した範囲内にあるかどうか判定 参考にしたサイト JSでIPアドレス(IPv4)が指定したサブネットの範囲に含まれるか判定するロジックを作った時の記録です。 IPアドレスが指定した範囲内にあるかどうか判定 処理としては、IP…

プログラムの数値計算で発生する誤差の種類 丸め誤差・打ち切り誤差・桁落ち
はじめに 誤差の種類 丸め誤差 打ち切り誤差 桁落ち 情報落ち 桁溢れ誤差 参考にしたサイト コンピュータで出てくる誤差はいくつかありますが、 それらをコードに落として整理しました。 はじめに 例えば の計算の答えは 0.6666666666…

Tags

Dates

© 2021   404 motivation not found