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
17
サーバーサイドな人がフロントエンド技術と仲良くするはじめの一歩
nabedge
0
17
Selenium再入門
nabedge
0
15
Webエンジニアがスタートダッシュをキメるためのローカル開発環境の勘所
nabedge
0
16
テストゼロからイチに進むための戦略と戦術
nabedge
0
14
あなたのプロジェクトが気軽にJavaをバージョンアップするために必要なこと
nabedge
0
9
Other Decks in Technology
See All in Technology
Secrets of a PowerShell "Guru"
guyrleech
1
120
Oracle Base Database Service 技術詳細
oracle4engineer
PRO
5
38k
RailsConf 2024 Keynote "Startups on Rails in 2024"
irinanazarova
0
200
生成AIと産業向けソフトウェアの自動生成 〜 ハノーバーメッセ2024より〜
kioto
2
400
Exadata Database Service on Dedicated Infrastructure(ExaDB-D) UI スクリーン・キャプチャ集
oracle4engineer
PRO
2
1.7k
成長をサポートするピープルマネジメントのやり方
sioncojp
9
1.5k
【基本】データベース設計
oracle4engineer
PRO
2
310
株式会社EventHub・エンジニア採用資料
eventhub
0
2.1k
TDD - Test Driven Drupal
opdavies
0
3k
サービス開発におけるVue3とTypeScriptの親和性について
tsukuha
9
1.7k
知識と実践を紡ぐGenAI / Connecting Knowledge and experience with GenAI
aki_moon
2
130
令和版ソフトウェアエンジニアの情報収集術 PHPカンファレンス香川2024
ysknsid25
4
810
Featured
See All Featured
The Invisible Side of Design
smashingmag
294
49k
Faster Mobile Websites
deanohume
300
30k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
14
1.5k
Intergalactic Javascript Robots from Outer Space
tanoku
266
26k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
188
16k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
20
1.8k
Embracing the Ebb and Flow
colly
80
4.2k
Product Roadmaps are Hard
iamctodd
45
9.8k
4 Signs Your Business is Dying
shpigford
176
21k
The Pragmatic Product Professional
lauravandoore
26
5.9k
Build The Right Thing And Hit Your Dates
maggiecrowley
25
2k
Facilitating Awesome Meetings
lara
43
5.6k
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()でやって、他の手段でそれを実行するこ とも可能。超疑り深い人用。
おしまい