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
実演!トランザクション
Search
よしたろう
July 04, 2021
Programming
0
26
実演!トランザクション
トランザクションの実演用資料
よしたろう
July 04, 2021
Tweet
Share
More Decks by よしたろう
See All by よしたろう
【登壇版】人はなぜ変われないのか?自分を変えるとは何か?どう在るべきなのか?
yoshitaroyoyo
0
3
人文学から学ぶ 人として、リーダーとして、スクラムマスターとしてのより善い在り方【完全版】
yoshitaroyoyo
0
3
自分を変えるを邪魔するのは自分自身!? 免疫マップで可視化てみよう!
yoshitaroyoyo
0
2
今、人類史上で最もリベラルアーツが必要な時代になっている.pdf
yoshitaroyoyo
0
33
銀河英雄伝説・攻殻機動隊 から人としてのあり方を学んだ
yoshitaroyoyo
1
31
視点の探索と取得〜見える世界が変わるとは何か?何が見えるようになるのか?
yoshitaroyoyo
1
100
フォロワーを活かすリーダー リーダーを活かすフォロワー
yoshitaroyoyo
2
140
対話・多様性が イノベーション・情報精緻化・組織学習に繋がる
yoshitaroyoyo
1
60
人文学から学ぶ 人として、リーダーとして、スクラムマスターとしてのより善い在り方
yoshitaroyoyo
3
1.8k
Other Decks in Programming
See All in Programming
React は次の10年を生き残れるか:3つのトレンドから考える
oukayuka
15
4.6k
TypeScriptでDXを上げろ! Hono編
yusukebe
3
770
The Modern View Layer Rails Deserves: A Vision For 2025 And Beyond @ RailsConf 2025, Philadelphia, PA
marcoroth
2
730
#QiitaBash MCPのセキュリティ
ryosukedtomita
1
1.5k
テスターからテストエンジニアへ ~新米テストエンジニアが歩んだ9ヶ月振り返り~
non0113
2
220
PHP 8.4の新機能「プロパティフック」から学ぶオブジェクト指向設計とリスコフの置換原則
kentaroutakeda
2
1k
20250708_JAWS_opscdk
takuyay0ne
2
130
フロントエンドのパフォーマンスチューニング
koukimiura
5
2k
What's new in AppKit on macOS 26
1024jp
0
150
AI時代の『改訂新版 良いコード/悪いコードで学ぶ設計入門』 / ai-good-code-bad-code
minodriven
24
9.6k
Agentic Coding: The Future of Software Development with Agents
mitsuhiko
0
130
型で語るカタ
irof
0
700
Featured
See All Featured
Fashionably flexible responsive web design (full day workshop)
malarkey
407
66k
Fireside Chat
paigeccino
37
3.5k
Adopting Sorbet at Scale
ufuk
77
9.5k
Rebuilding a faster, lazier Slack
samanthasiow
83
9.1k
Optimising Largest Contentful Paint
csswizardry
37
3.3k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
3.1k
Faster Mobile Websites
deanohume
308
31k
Learning to Love Humans: Emotional Interface Design
aarron
273
40k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
108
19k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
53
2.9k
Build your cross-platform service in a week with App Engine
jlugia
231
18k
Transcript
τϥϯβΫγϣϯͱʁɹɹ ᶃBEGIN/COMMIT/ROLLBACK ᶄτϥϯβΫγϣϯͷඞཁੑ ᶅτϥϯβΫγϣϯॲཧ͕ඞཁͳέʔε ᶆτϥϯβΫγϣϯ ࣮ࡍͷૢ࡞ํ๏
τϥϯβΫγϣϯͱʁɹɹ ᶃBEGIN/COMMIT/ROLLBACK ᶄτϥϯβΫγϣϯͷඞཁੑ ᶅτϥϯβΫγϣϯॲཧ͕ඞཁͳέʔε ᶆτϥϯβΫγϣϯ ࣮ࡍͷૢ࡞ํ๏
τϥϯβΫγϣϯͱʁɹɹ ɾinsert → ࣮ߦޙʹଈө ɾupdate → ࣮ߦޙʹଈө ɾdelete → ࣮ߦޙʹଈө
τϥϯβΫγϣϯͱʁɹɹ τϥϯβΫγϣϯෳͷߋ৽ΛҰׅཧ ·ͱΊͯөͤ͞Δ͜ͱ͕Ͱ͖Δ ɾinsert → ࣮ߦޙʹଈө ɾupdate → ࣮ߦޙʹଈө ɾdelete
→ ࣮ߦޙʹଈө
τϥϯβΫγϣϯͱʁɹɹ BEGIN /// τϥϯβΫγϣϯ։࢝ ɾinsert ɾupdate ɾdelete COMMIT /// Ұׅө
ROLLBACK /// Ұׅऔফ
τϥϯβΫγϣϯͷඞཁੑ ᶃBEGIN/COMMIT/ROLLBACK ᶄτϥϯβΫγϣϯͷඞཁੑ ᶅτϥϯβΫγϣϯॲཧ͕ඞཁͳέʔε ᶆτϥϯβΫγϣϯ ࣮ࡍͷૢ࡞ํ๏
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert τϥϯβΫγϣϯͳ͠ͷ߹ ɾΫϨδοτΧʔυܾࡁʹࣦഊͨ͠߹ʁ
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert τϥϯβΫγϣϯͳ͠ͷ߹ ɾΫϨδοτΧʔυܾࡁʹࣦഊͨ͠߹ʁ ɾࡏݿςʔϒϧͷΞοϓσʔτ͍ྃͯ͠Δ
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert τϥϯβΫγϣϯͳ͠ͷ߹ ɾΫϨδοτΧʔυܾࡁʹࣦഊͨ͠߹ʁ ɾࡏݿςʔϒϧͷΞοϓσʔτ͍ྃͯ͠Δ
ɾͷߪೖʹࣦഊͨ͠ʹؔΘΒͣࡏݿ͕ݮΔ
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert τϥϯβΫγϣϯͳ͠ͷ߹ ɾΫϨδοτΧʔυܾࡁʹࣦഊͨ͠߹ʁ ɾࡏݿςʔϒϧͷΞοϓσʔτྃͯ͠͠·ͬͨ
ɾͷߪೖʹࣦഊͨ͠ʹؔΘΒͣࡏݿ͕ݮΔ ˠσʔλෆ߹Λىͨ͘͜͠ͳ͍ͧʂʂ
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert BEGINʢ։࢝ʣ τϥϯβΫγϣϯ͋Γͷ߹
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert BEGINʢ։࢝ʣ ROLLBACKʢҰׅऔফʣ τϥϯβΫγϣϯ͋Γͷ߹
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert BEGINʢ։࢝ʣ τϥϯβΫγϣϯ͋Γͷ߹
τϥϯβΫγϣϯͷඞཁੑ ྫʣECαΠτͰͷߪೖॲཧ ᶃࡏݿςʔϒϧͷ update ᶄΫϨδοτΧʔυܾࡁॲཧ(API) ᶅߪೖཤྺςʔϒϧͷ insert BEGINʢ։࢝ʣ COMMITʢҰׅөʣ τϥϯβΫγϣϯ͋Γͷ߹
τϥϯβΫγϣϯͱʁɹɹ ᶃBEGIN/COMMIT/ROLLBACK ᶄτϥϯβΫγϣϯͷඞཁੑ ᶅτϥϯβΫγϣϯॲཧ͕ඞཁͳέʔε ᶆτϥϯβΫγϣϯ ࣮ࡍͷૢ࡞ํ๏
τϥϯβΫγϣϯ͕ඞཁͳέʔε ɾखಈͰSQLίϚϯυૢ࡞͢Δ࣌ ɾෳσʔλͷ߹ੑΛอ͍ͪͨ࣌
τϥϯβΫγϣϯͱʁɹɹ ᶃBEGIN/COMMIT/ROLLBACK ᶄτϥϯβΫγϣϯͷඞཁੑ ᶅτϥϯβΫγϣϯॲཧ͕ඞཁͳέʔε ᶆτϥϯβΫγϣϯ ࣮ࡍͷૢ࡞ํ๏
None
None