EMecha - EMsql
EMsqlとは?
外だしsQL(Outsidesql)のsQLファイルの実装支援を行う EMecha の中の一機能(EMechaがインストールされていれば利用可能)。これを利用すると、より安全な外だしsQLライフが送れます。
ゆえに EMecha は、(アーキテクトだけでなく)ディベロッパーもインストールするのがお奨めです。
外だしsQLの新規作成
sql2Entityマークなどの設定を画面上で行い、外だしsQL用のsQLファイルを新規作成します。
Behaviorを選んで画面を起動
Package Explorer 上で対応する Behavior クラス(Exクラスのソースファイル)を選択して右クリックし、EMecha - New Outside sql と選択すると画面が起動します。
対応する Behavior のソースファイルまでは、リソースの検索(ctrl + shift + R)から対応する Behavior を開き、Package Explorer の右上の方にある "Link with Editor" を押して階層を開くと良いでしょう。
sQL Name を入力
初期状態では、select が選択されていています。検索系のsQLであればそのまま sQL Name の select に続けてsQL業務名を入力します。検索でなければ該当するものを選択してsQL名を完成させます。
sQLのタイトル・説明
画面からは、タイトルのみを入力します。 説明は、sQLを実装しながらでないと書きにくいと思われるため、sQLファイルが作成されてからエディタで記述するようにしています。
タイトルを入力しない場合は、タイトル・説明自体のコメント欄自体が出力されません。タイトルなしで説明だけを利用する状況は想定していません。
sql2Entityマーク
利用したいsql2Entityマークにチェックしていきます。TypedParameterBean の利用を想定して、ある程度デフォルトでチェックが付いています。ページングか否か、戻り値 Entity の型(カーソルも含む)などオプション項目を要件に応じてチェックして下さい。
出力されるsql2Entityマークは、"df:entity" や "df:pmb" といったような、sQLの名前からEntity名やPmb名を抽出する方式のものになります。 もし、(sQLの名前とは違う)独自の名前を利用する場合は、sQLファイルが作成されてからエディタで修正して下さい。
出力先ディレクトリ
sQLファイルは、Eclipseプロジェクト直下の src/main/resources 配下の、対応するBehaviorと同じパッケージ に作成されます。ただ、これはデフォルト値であり、画面上で変更可能です。
エンコーディング
sQLファイルは、UTF-8 で作成されます。
外だしsQLへ飛ぶ!
ソースコード上の ParameterBean や CustomizeEntity から、対象となる外だしsQLをエディターで開くことができます。@since EMecha-0.5.6
クラス名にカーソル合わせて ctrl すると、"sQLを開く" というメニューが出てくるので、それをクリックすると対応する外だしsQLが開きます。
ParameterBeanから外だしsQLにctrl + クリック @Java
//
// クラス名のところでカーソル合わせて ctrl すると、
//
// _/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
// o Open Declaration
// o sQLを開く
// o CustomizeEntityを開く
// _/_/_/_/_/_/_/_/_/_/
//
// がポップアップで表示される
// "sQLを開く" をクリックすれば外だしsQLへ!
//
PartOfMemberPmb pmb = new PartOfMemberPmb();
...
さらに、ParameterBeanなら "CustomizeEntityを開く"、CustomizeEntityなら "ParameterBeanを開く" が利用できます。(対応するクラスが存在しない場合は表示されません)
また、ctrl ではなく alt + クリックであれば、問答無用で "sQLを開く" になります。
厳密には、EMsqlではなくDFAssistの機能です。(内部的なお話です)