JDBI
簡単にパフォーマンスチェックをしてみます。 id、name を持つテーブルに1万件insertしてみました。 特に意外な結果にはならなかったので、問題ないかなと思います。結果はソース中にコメントで書いておきました Dao019.java public interface Dao019 { @Sql…
log4j で簡単にログ出力できます。 DBIにログ設定したり、Handleにもログ設定できます。 必要なところだけロギングしたければHandleに設定すればよいでしょう。 log4j.jar をクラスパスに加えないとコンパイルできないかもしれませんのでご注意を。 Sample02…
一応こんなこともできるというご紹介で、前回は1レコードだけinsertしたIDを取得する処理でしたが、今回は複数レコード対応です。 insert select で複数レコード登録した際に、それらのIDがListで返ってきます。 Dao017.java public interface Dao018 { @Sql…
よくあるRESTのパターンとして、IDはシーケンスを設定しておき、APIから指定された内容を登録したらIDを返す、というもの。JDBIではどうやればいいのかというサンプルです。 Dao017.java public interface Dao017 { @SqlUpdate("CREATE SEQUENCE seq") void …
今まで、DBIオブジェクト or HandleオブジェクトからDaoを取得してきましたが、今度は逆にDaoからHandleオブジェクトを取得してみましょう。取得するには、「getHandle」メソッドを宣言すればいいのですが、今回は予めJDBI側で用意されているMixin用のinterf…
Handleから自前でトランザクション制御するのは以前やりましたが、Daoでもできますのでそのサンプルです。敢えてこの方法でトランザクション処理を書く必要は無さそうですけど、一応こんなこともできますよーという意味で。 Dao015.java public interface Da…
今までトランザクション中に例外が発生すれば自動的にRollbackされることを確認してきましたが、例外が起きなくてもRollbackさせたい場合があるので、そのサンプルです。 Sample023.java public static void main(String[] args) { String url = "jdbc:postg…
前回の続きです。ObjectAPI形式とFluent形式を融合させてトランザクション処理をしてみますが、やってはいけないサンプルです。 Daoのメソッドに Transaction アノテーションを付けるとどうなるかやってみます。 Sample022.java public static void main(Str…
今回からObjectAPI形式とFluent形式を融合させてトランザクション処理をしてみましょう。まずは簡単なサンプルを。 2つ Handle を作って、1つは inTransaction メソッドでトランザクション処理を書きます。こいつは勝手にbegin〜commit〜rollbackをしてくれ…
前回、複数Daoにまたがる場合のトランザクション処理をやってみましたが、あの設計だと複数人で開発した場合早晩破綻するのでもうちょっと工夫してみましょう。 登場人物は以下の3つ。 単純なDao。基本的にテーブルに付き1つのDaoが作られる。これには Trans…
今度は、複数Daoにまたがる場合のトランザクション処理をやってみましょう Dao013.java public interface Dao013 { @SqlUpdate("insert into table001 (id, name) values (:id, :name)") int insert(@Bind("id") int id, @Bind("name") String name); } Dao0…
前回からの続きですが、ObjectAPI形式で引数を自前でバインドする方法です Dao012.java public interface Dao012 { @SqlUpdate("insert into table001 (id, name) values (:id, :name)") void insert(@BindMap Map<String,Object> map); @SqlQuery("select name from table0</string,object>…
ObjectAPI形式の場合、引数にBeanがいくつもあった場合、同じフィールド名がかぶってしまう可能性があるので、そんな時にどのBeanがどのパラメータにバインドさせるかちゃんと指定できるようします Dao011.java public interface Dao011 { @SqlUpdate("inser…
次はDaoに@Transactionアノテーションを付けてトランザクション制御してみます Dao010.java public abstract class Dao010 { @SqlUpdate("insert into table001 (id, name) values (:id, :name)") public abstract int insert(@Bind("id") int id, @Bind("na…
お次はバカ正直に自分でトランザクションを制御します Sample015.java public static void main(String[] args) { String url = "jdbc:postgresql://192.168.52.128/jdbi"; DBI dbi = new DBI(url, "jdbi_user", "jdbi_pass"); Handle h = dbi.open(); Syste…
実は SqlBatch アノテーションを付ければ勝手にトランザクション処理をしてくれます Dao008.java public interface Dao008 { @SqlBatch("insert into table001 (id, name) values (:id, :name)") int[] insertBatch(@Bind("id") List<Integer> ids, @Bind("name") List<String></string></integer>…
配列とかListを引数に渡せば、勝手にその配列数分ループして実行してくれます Dao007.java public interface Dao007 { @SqlBatch("insert into table001 (id, name) values ((select count(*)+1 from table001), :first || '-' || :last)") int[] insertBatc…
前回はselectの結果を任意のモデルに変換する処理をやってましたが、当然insertやupdateでもできます。 Dao006.java public interface Dao006 { @SqlQuery("select name from table001 where id = :id") String findNameById(@Bind("id") int id); @SqlUpdat…
JDBIを普通に使ってると、DaoとModelが別ファイルになっちゃうのですが、一応こうやれば同じクラスで実装できます。でもあまりよろしく無さそうですね。 Table002.java public class Table002 { private int id; private String name; public Table002(){} p…
前回の続きでObjectAPI形式の場合に自分で戻り値の型をマッピングする処理を書いてみましょう Dao004.java public interface Dao004 { public static class SimpleMapper implements ResultSetMapper<Map<String,Object>> { public Map<String,Object> map(int index, ResultSet r, StatementCo</string,object></map<string,object>…
今までもずっと使ってたんですけど、ObjectAPI形式の場合は @SqlQuery アノテーションを付けたメソッドの戻り値によって、JDBIが勝手に推測して相応の処理をしてくれます。 Dao003.java public interface Dao003 { @SqlQuery("select id from table001") List<Integer></integer>…
ObjectAPI形式だけを使用する場合、DBI.onDemand で勝手にopen、closeしてくれます。 Dao002.java public interface Dao002 { @SqlUpdate("create table IF NOT EXISTS table002 (id int primary key, name varchar(100))") void createTable(); @SqlUpdate(…
例えば name 列だけ一覧でほしいという場合、前回の方法だと一度全部取得してから、name列だけを再度取得する、という2段階になるので少し面倒です。そんな時に使うテクニック Sample006.java public static void main(String[] args) { String url = "jdbc:…
今までは1行目の検索結果だけ取得してましたが、検索結果の全行を取得してみましょう Sample005.java public static void main(String[] args) { String url = "jdbc:postgresql://192.168.52.128/jdbi"; DBI dbi = new DBI(url, "jdbi_user", "jdbi_pass");…
DBI.withHandle メソッドを使えば、コールバックでHandleをもらって、自動的にcloseしてくれます。ruby みたいで便利ですね。 それ以外は特に説明不要かな。 Sample004.java public static void main(String[] args) { String url = "jdbc:postgresql://192.…
では前回の予告通り、今回は Object形式とFluent形式の両方を同じコネクションで使用してみましょう。 Daoを生成する時、DBI.open ではなく、Handle.attach を使用します public static void main(String[] args) { String url = "jdbc:postgresql://192.168…
まずは前回の Dao001.java を使用して、単純に2つのAPI形式で実行してみましょう Sample002.java public static void main(String[] args) { String url = "jdbc:postgresql://192.168.52.128/jdbi"; DBI dbi = new DBI(url, "jdbi_user", "jdbi_pass"); Dao…
Dao001.close() というメソッドは何も実装を書いてないけど、宣言だけしておけばJDBIが勝手にリソースを解放する処理を注入してくれる。 ちなみにこの形式を「SQL Object API」と呼ぶそうです。ちなみに前回のように、生のSQLをそのまま実行するのが「Fluent…
DropWizardを研究してるというよりはJDBIを研究してる状況になったので、JDBI単体で色々実験してみる。まずは超簡単なサンプル String url = "jdbc:postgresql://192.168.52.128/jdbi"; // IPアドレス、データベース名は適当に変更すること DBI dbi = new DB…