Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
jOOQってなんて読むの?から始めるSpringBootとO/Rマッパーの世界
Search
Yu Watanabe
February 10, 2016
Technology
0
21
jOOQってなんて読むの?から始めるSpringBootとO/Rマッパーの世界
Yu Watanabe
February 10, 2016
Tweet
Share
More Decks by Yu Watanabe
See All by Yu Watanabe
JUnitテストをCI環境で並列で実行する方法とその速度, スケーラビリティ
nabedge
4
1.5k
クラウド時代だからSpring-Retryフレームワーク
nabedge
0
24
ツール比較しながら語るO/RマッパーとDBマイグレーション
nabedge
0
32
JavaでWebサービスを作り続けるための戦略と戦術
nabedge
0
15
サーバーサイドな人がフロントエンド技術と仲良くするはじめの一歩
nabedge
0
15
Selenium再入門
nabedge
0
15
Webエンジニアがスタートダッシュをキメるためのローカル開発環境の勘所
nabedge
0
16
テストゼロからイチに進むための戦略と戦術
nabedge
0
14
あなたのプロジェクトが気軽にJavaをバージョンアップするために必要なこと
nabedge
0
7
Other Decks in Technology
See All in Technology
LayerXにおけるLLMプロダクト開発の今までとこれから
layerx
PRO
4
740
Além do else! Categorizando Pokemóns com Pattern Matching no JavaScript
wmsbill
0
710
今日からできる!簡単 .NET 高速化 Tips -2024 edition-
xin9le
7
4k
IaCジェネレーターとBedrockで詳細設計書を生成してみた
tsukasa_ishimaru
4
890
M5stackで使用できるpHセンサの開発
shinrinakamura
0
200
M&A戦略を支えるデータマネジメント (MIDAS Tech Study #16 GENDA Komiyama)
kommy339
1
120
実例で紹介するRAG導入時の知見と精度向上の勘所
yamahiro
5
1.7k
Documentação de Produtos: Artefatos essenciais na prática
rigolon
1
140
R3のコードから見る実践LINQ実装最適化・コンカレントプログラミング実例
neuecc
3
2.7k
Cracking the KubeCon CfP
inductor
2
270
今年のRubyKaigiはProfiler Year🤘
osyoyu
0
410
BPStudyの200回を中心にIT業界を振り返る。そしてこれから
haru860
3
410
Featured
See All Featured
Designing the Hi-DPI Web
ddemaree
276
33k
The Art of Programming - Codeland 2020
erikaheidi
43
12k
Building Effective Engineering Teams - LeadDev
addyosmani
31
1.9k
Designing for Performance
lara
601
67k
The Pragmatic Product Professional
lauravandoore
26
5.8k
Atom: Resistance is Futile
akmur
260
25k
GitHub's CSS Performance
jonrohan
1025
450k
Designing with Data
zakiwarfel
96
4.8k
Designing Experiences People Love
moore
136
23k
Clear Off the Table
cherdarchuk
85
310k
jQuery: Nuts, Bolts and Bling
dougneiner
59
7.2k
Testing 201, or: Great Expectations
jmmastey
30
6.4k
Transcript
“jOOQってなんて読むの?” から始める SpringBootと O/Rマッパーの世界 The “Garden” at Bizreach.inc, Shibuya, Tokyo
2016-02-08 @nabedge わたなべ
Who ? • わたなべ ◦ twitter: @nabedge ◦ (株)ビズリーチ SREグループ
エンジニア ◦ O/Rマッパの使用経験 ▪ O/Rマッパ使うなど軟弱ゥ -> S2JDBC -> MyBatis -> -> DBFlute -> QueryDSL...そしてjOOQを試し中 • 過去の講演資料など ◦ http://www.slideshare.net/nabedge/presentations
今日の流れ 1. 参加者全員による自己紹介 a. お名前 b. 業種、職種 (例:会計処理パッケージソフト屋でJava書いてます) c. 最近使っている
RDBMSと、O/Rマッパーは? (例:OracleとMyBatis) 2. jOOQの概要 3. デモいろいろ 4. まとめ
jOOQ概要
jOOQってなんて読むの?
汎用言語とDSL 汎用言語 DSL Domain Specific Language = ドメイン特化言語 エクセルマクロ 正規表現
SQL Makefile Java C言語 HTML
つまりjOOQとは? • SQLをJavaで書け る”internal DSL” (意訳: オレオレDSL) を提供するJavaライブラリと ツールのこと。
jOOQの開発元(の収入源)は?
DEMO https://github.com/nabedge/jooq-demo2
まとめ
Java, SQL, jOOQ • DSL = Domain Specific Language =
ドメイン特化言語 • jOOQとは? ◦ SQLをJavaで書ける”internal DSL” (意訳: オレオレDSL) を提供するJava-APIライブラリとツール • jOOQの効果は? ◦ Java上でタイプセーフにSQLを書いて実行できる
Javaエンジニアにとっての生産性って、 タイプセーフのことですよね。 • CTRL+Spaceキーだけでなんとなく仕事が進められる。 • 書き間違えるとコンパイルエラーでわかる。 実行して初めて間違いがわかるより早い • DB定義を変更するとコンパイルエラーでわかる。 テーブル定義の影響範囲がすぐわかるため
開発とテストをしやすくなる。
jOOQの使い方ざっくり(1) 1. テーブルを張った状態のDBを用意する a. sql-maven-plugin あるいは Flyway が便利 2. jOOQ
+ maven or gradle or API直たたき で、 jOOQ-DSL的なJavaコードを自動生成する 3. 自動生成したコードをIDE上でソースコード扱い(コンパイル対象)にする a. src/main/java 配下に出力するならそこをVCS管理にするかignoreするかは要 検討 b. target/generated-sources (デフォルト)配下に出力するならIDEの設定に少し 注意
jOOQの使い方ざっくり(2) 4. ビジネスロジック層(リポジトリ層)のJavaクラス内で、 自動生成したコードを使ってSQLを組んで実行 5. テーブル定義の変更の場合は1に戻ってやり直すだけ
jOOQでのCRUD • 先ほどデモしたとおりです • デモのコードは https://github.com/nabedge/jooq-demo2 • UpdatableRecordはRuby on RailsでいうActiveRecordに近いらしい
SpringBootとjOOQとトランザクション管理 • SpringBootにはjOOQのDslContextクラスのインスタンスを使うための設定が初め から組み込まれている • “@Transactional” をクラスまたはメソッドにつけるだけでトランザクションに包まれる • @Transactionalの中であれば異なるO/Rマッパを使っても同じトランザクションで管 理される
◦ 全てのO/RマッパのインスタンスがSpring配下で一元管理されたDataSourceを使っているのが前提 (次ページ参照)
どうやってjOOQに移行しようか? • 他のO/Rマッパ(MyBatis, JdbcTemplate, etc)のDataSourceの 管理が、Springの管理下にあるかどうか ヒント:TransactionAwareDataSourceProxy • 正しくSpringを使えばO/Rマッパの複数併用は可能 ◦
併用の例はサンプルコードみてね • 併用しながら徐々にjOOQで書き直せばいい
疑り深いあなたのために • 実際に組み立て&発行されるSQL文を JDBCのレベルでトラップして確認するには? -> log4jdbcをどうぞ • そんなことしなくてもjOOQならSQL文のログ出力機能が初めからあるけどね。 ◦ ただし
“commit”, “rollback” の実行までをもログに吐く にはlog4jdbcしかなさそう。 • jOOQを使いつつ「手組み」の文字列をSQLに含めることも可能 ◦ https://www.jooq.org/doc/3.9/manual/sql-building/plain-sql/ • SQL文の組み立てだけをjOOQのgetSQL()でやって、他の手段でそれを実行するこ とも可能。超疑り深い人用。
おしまい