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
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Yu Watanabe
February 10, 2016
Technology
150
0
Share
jOOQってなんて読むの?から始めるSpringBootとO/Rマッパーの世界
Yu Watanabe
February 10, 2016
More Decks by Yu Watanabe
See All by Yu Watanabe
JUnitテストをCI環境で並列で実行する方法とその速度, スケーラビリティ
nabedge
5
2.8k
クラウド時代だからSpring-Retryフレームワーク
nabedge
0
310
ツール比較しながら語るO/RマッパーとDBマイグレーション
nabedge
0
160
JavaでWebサービスを作り続けるための戦略と戦術
nabedge
0
94
サーバーサイドな人がフロントエンド技術と仲良くするはじめの一歩
nabedge
0
78
Selenium再入門
nabedge
0
66
Webエンジニアがスタートダッシュをキメるためのローカル開発環境の勘所
nabedge
0
83
テストゼロからイチに進むための戦略と戦術
nabedge
0
95
あなたのプロジェクトが気軽にJavaをバージョンアップするために必要なこと
nabedge
0
63
Other Decks in Technology
See All in Technology
PdM・Eng・QAで進めるAI駆動開発の現在地/aidd-with-pdm-eng-qa
shota_kusaba
0
240
R&D 祭 2024 UE5で絵コンテ・作画の制作支援ツールをつくる話
olmdrd
PRO
0
140
なぜ、私がCommunity Builderに?〜活動期間1か月半でも選出されたワケ〜
yama3133
0
130
Databricks 月刊サービスアップデートまとめ 2026年04月号
tyosi1212
0
120
生成AI時代に信頼性をどう保ち続けるか - Policy as Code の実践
akitok_
1
410
SREの仕事は「壊さないこと」ではなくなった 〜自律化していくシステムに、責任と判断を与えるという価値〜 / 20260515 Naoki Shimada
shift_evolve
PRO
1
160
SLI/SLO、「完全に理解した」から「チョットデキル」へ
maruloop
5
510
オライリーイベント登壇資料「鉄リサイクル・産廃業界におけるAI技術実応用のカタチ」
takarasawa_
0
410
AI時代に越境し、 組織を変えるQAスキルの正体 / QA Skills for Transforming an Organization
mii3king
5
4.4k
Gaussian Splattingの表現力を拡張する — 高周波再構成とインタラクションへのアプローチ —
gpuunite_official
0
180
JTCでRedmine利用者2700人を実現した手法 第二部
nobuonakamura
0
110
Oracle AI Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
4
2.6k
Featured
See All Featured
Mind Mapping
helmedeiros
PRO
1
190
Deep Space Network (abreviated)
tonyrice
0
140
Mobile First: as difficult as doing things right
swwweet
225
10k
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
110
SERP Conf. Vienna - Web Accessibility: Optimizing for Inclusivity and SEO
sarafernandez
2
1.4k
Side Projects
sachag
455
43k
Darren the Foodie - Storyboard
khoart
PRO
3
3.3k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.1k
ラッコキーワード サービス紹介資料
rakko
1
3.3M
The Anti-SEO Checklist Checklist. Pubcon Cyber Week
ryanjones
0
140
Claude Code のすすめ
schroneko
67
220k
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
1
210
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()でやって、他の手段でそれを実行するこ とも可能。超疑り深い人用。
おしまい