search
LoginSignup
33

More than 1 year has passed since last update.

posted at

Java O/Rマッパーの種類と選定方法について調べたことのメモ

O/Rマッパーとは

「O/Rマッパー」って名前、なんか小学生の必殺技的な響きしてますよね。
最近業務で色々なO/Rマッパーに触れる機会があったので、ついでに調べたことをざっくりまとめました。

O/Rマッピングとは、オブジェクト指向プログラミング言語におけるオブジェクトとリレーショナルデータベース(RDB)の間でデータ形式の相互変換を行うこと。
IT用語辞典 -O/Rマッパーとは

簡単に言うとJavaなどのプログラミング言語とRDBの橋渡しをしてくれるものです。

もっと詳しく知りたい方
オブジェクト関係マッピング
O/Rマッピングの役割とメリット

先に結論

それぞれメリット・デメリットがあるため、どのO/Rマッパーが良いかはプロジェクト次第。
色々調べるよりまずはこれ読んでください。Java ORマッパー選定のポイント

O/Rマッパーの分類

要約するとこんな感じ。
JDBCラッパー型   初心者にとって理解しやすい。冗長的になりやすい。
SQLマッパー型     ↑
クエリビルダー型    ↓
O/Rマッパー型   学習コストがかかる。自由度が高いが運用の難易度も極めて高い。
下記は代表的なO/Rマッパーをリストアップしました。

  • JDBCラッパー型
    • Spring JDBC
    • DbOom
    • Apache Commons DbUtils
    • sql2o
  • SQLマッパー型
    • MyBatis
    • DOMA
    • Migrate SQL
    • jdbi
  • クエリビルダー型
    • jOOQ
    • DBFlute
    • Reladomo
    • Querydsi
    • Ebean
    • Speedment
    • Jinq
    • requery
    • Cayenne
    • Torque
  • O/Rマッパー型
    • JPA
    • EclipseLink
    • Hibernate

各O/Rマッパーの特徴

Spring JDBC

Spring Framework内で使用できるJDBCラッパー。
⭕️ Connection、PreparedStatementを開発者が意識しなくて良い。
⭕️ ResultSetから詰め替えるところを記述するだけで良い。
⭕️ Java EE環境など他の環境でも使える。
⭕️ 初心者がプログラミング言語とRDBとの繋がりを理解しやすい。
❌ SQL部分をクラスファイルにベタ書きするため、同じようなデータを取得する際に使いまわすことができない。やや冗長。メンテナンス性が悪い。
❌ Javaのクラスファイルにベタ書きするため、コーディング中に文法等のエラーを検知しない。そのため、実行して初めて気づくことが多い。

iciql

JDBCのライブラリ集の一つ。
⭕️ 単一のjarファイルで提供されている
⭕️ 設定ファイル無しで使用可能(xmlで設定する必要なし)
⭕️ JDBCの記述を簡素化することができる。
❌ 自動生成されるSQLの日付関連の処理に課題があるらしい?
[Java]iciqlで簡単DBアクセス[ORマッパー]
ICIQL導入をしてみる
O/Rマッパー iciqlについて

DbOom

JDBCのライブラリ集の一つ。
⭕️ 単一のjarファイルで提供されている
⭕️ JDBCの記述を簡素化することができる。
❌ 日本語の文献が少ない
DbOom(公式)
以下下記サイトのコピペJavaのDBアクセスライブラリ比較

Joddは機能ごとに切出せて何かと使いやすそう。
実行されるSQLをパラメタ埋め込み状態で取得でき、デバッグに有利。
Modelをそのまま保存できるinsert()あり。updateにも補助スクリプトあり。
セッションとかの機能もついてるのはいいかも。
トランザクションは一通りのサポートあり。
Camel <-> snake 変換機能あり。
キャッシュもあるらしい。
初期設定は自分で細々積み上げる必要があるが、必要な道具は一通り揃ってる感じ。
余計なことしないのはいいけど、面倒かも。
JoddのJTXは他のライブラリ使うときも切り出して使えそう。

Apache Commons DbUtils

JDBCのライブラリ集の一つ。ライブラリ自体の記述量が少なく、高速に動かすことを目的としている。
⭕️ 単一のjarファイルで提供されている
⭕️ JDBCの記述を簡素化することができる。
❌ あまり高度な機能はない。
Apache Commons DbUtils(公式)

MyBatis

SQLマッパー型。
SQLをXMLファイルに記述する。
⭕️ 公式ドキュメントが超他言語対応しているため、オフショア開発や英語アレルギーの日本人にも優しい笑。(英語・日本語・中国語・スペイン語・・・)
⭕️ SQLの自由度が高い
❌ XMLのルールが面倒。不等号や条件分岐の記述の扱いをしっかり理解する必要がある。

DOMA

SQLマッパー型。
個人用のプロジェクトや複雑な処理がないシステムにピッタリのO/Rマッパー。エンティティ一つでCRUDできる処理が多い場合に用いられる。
⭕️ 2WaySQL。

2WaySQLとは、簡単に言うと、SQLをそのまま貼り付けても実行できるし、アプリケーションでパラメータを可変にしても実行できるというSQLのことです。

引用元【超初心者向け】MirageSQL超入門
⭕️ DBの1つのエンティティに対してのDMLを自動で用意してくれる。
❌ テーブル結合を要するSQLの場合はカスタムクエリを作成する必要がある。
❌ 一つのクラスファイルで二つのSQLを使用することはできない。一つ目のSQLだけしか実行されない。

jOOQ

クエリビルダー型。
⭕️ SQLが自動生成されるため、タイプミスの心配がない。
❌ 複雑なSQLを表現するのに限界がありそう?

JPA

O/Rマッパー型。
JPAは「仕様」に過ぎないため、単体で使うのではなくeclipseLinkやHibernateで実装する必要がる。
JPAは高度なことができる分、学習コストが桁違い。安易に導入すべきではない?
やはりこのサイト、最強。。。
Java ORマッパー選定のポイント(再掲)

①DBを新規に登録できる
② 集合演算やFROM句での副問合せなど、
 複雑なSQLは要件的に少ない
③ 「パーフェクトJava EE」を読破した⼈が
 プロジェクトに1⼈以上いる
1つでも当てはまらない項⽬があれば、 他のORマッパーを使った⽅がいいかも

⭕️ ベンダーサポートがある。標準技術になっている。
❌ JPAの仕様書は英語で600ページ以上学習コストが高い!ムリ!ヨミタクナイ!

eclipseLink

O/Rマッパー型。
JPAを実装するために用いる。
フレームワーク内部の処理によってSQLを自動生成してくれる。
Hibernateとやりたいことは同じだが、生成されるSQLに微妙な違いがあったりする。

Hibernate

O/Rマッパー型。
JPAを実装するために用いる。
フレームワーク内部の処理によってSQLを自動生成してくれる。
eclipseLinkとやりたいことは同じだが、生成されるSQLに微妙な違いがあったりする。

もっとマニアックなやつ(古いですが)

オープンソースJava O/Rマッピングソフト一覧(2014年1月版)

O/Rマッパーの選定方法

自分の手で書こうと思ったけど、やはりこの記事がとてもわかりやすかったので。もうこれみてください。てかここまで書いてきたけど最初からこの記事だけ見ればいいんじゃ、、、スライド62以降がもう答えなんじゃ(ry
Java ORマッパー選定のポイント

最後に

間違った点があれば遠慮なくご指摘ください。また、補足等があればコメントくださると幸いです。

いや、むしろ補足してください。
てか、本件について詳しい人、自分に教えろください。
必殺・O/Rマッパー!!!

参考文献

Java ORマッパー選定のポイント(再掲)
オブジェクト関係マッピング
DOMA
DOMA バインド変数コメント
mybatis
DBFlute
外だしSQL(OutsideSql)について
jOOQ
JavaのDBアクセスライブラリ比較
JPA、Hibernate、EclipseLinkの違い - Codeflow
JPAの基礎1(eclipseLinkについての記載有り)
【超初心者向け】MirageSQL超入門(再掲)
若手Javaエンジニア必見。知っておきたいフレームワーク・ツール23選
IT用語辞典 -O/Rマッパーとは(再掲)
[Java]iciqlで簡単DBアクセス[ORマッパー]
ICIQL導入をしてみる
DbOom(公式)
Apache Commons DbUtils(公式)

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
What you can do with signing up
33