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
DBMS を実装しながら学ぶ/cybozulabs-youth10-yamamoto
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Cybozu
PRO
March 31, 2021
Technology
560
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
DBMS を実装しながら学ぶ/cybozulabs-youth10-yamamoto
Cybozu
PRO
March 31, 2021
More Decks by Cybozu
See All by Cybozu
新卒1年目QAが リリース基準の"なぜ"をたどってみた
cybozuinsideout
PRO
1
280
サイボウズ 開発本部採用ピッチ / Cybozu Engineer Recruit
cybozuinsideout
PRO
10
82k
kintone リサーチ副部/UXリサーチャー 業務紹介
cybozuinsideout
PRO
0
80
私たちが『JaSST協賛』から『外部コネクト』チームになった理由
cybozuinsideout
PRO
0
360
LLMでもいつものテスト技術〜意外と半分はこれまでのテストでした〜
cybozuinsideout
PRO
1
890
kintone開発のプラットフォームエンジニアの紹介
cybozuinsideout
PRO
0
1.3k
LLMアプリの品質保証
cybozuinsideout
PRO
1
630
技術広報チームに丸投げしない!「一緒につくる」スポンサー活動
cybozuinsideout
PRO
0
240
テクニカルライター (グループウェア) について
cybozuinsideout
PRO
0
210
Other Decks in Technology
See All in Technology
Socrates × Looker 〜セマンティックレイヤーで進化するデータ分析エージェント〜
hanon52_
3
2.3k
【セミナー資料】Claude Code をセキュアに使うための考え方と設定の勘どころ / Claude Code Webinar 20260616
masahirokawahara
1
130
小さくはじめるSLI/SLO ~育てながら組織に定着させる実践知~ / Starting Small with SLI/SLOs: Building Adoption Through Continuous Growth
nari_ex
7
1.9k
エラーバジェットのアラートのタイミングを考える.pdf
kairim0
0
140
EventBridge Connection
_kensh
5
710
連合学習と機密コンピューティング
lycorptech_jp
PRO
0
110
AIエージェントが名古屋の猛暑からあなたを守る
happysamurai294
0
110
AIの性能が向上しても未解決な組織の重大問題は何か?/An Unsolved Organizational Problem in the Age of AI
moriyuya
4
650
入門!AWS Blocks
ysuzuki
1
110
FDE という解 ― 暗黙知と明示知をつなぐ、伴走型エンジニアリング ―
otanet
0
150
中期計画、2回作ってみた ~業務委託と正社員、両方の視点から~
demaecan
1
730
Kubernetesにおける学習基盤とLLMOpsの概要
ry
1
280
Featured
See All Featured
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
Darren the Foodie - Storyboard
khoart
PRO
3
3.4k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
170
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
The World Runs on Bad Software
bkeepers
PRO
72
12k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
62k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
200
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
30 Presentation Tips
portentint
PRO
1
320
How to build a perfect <img>
jonoalderson
1
5.6k
Transcript
DBMSを実装しながら学ぶ 山本祥平 1
自己紹介 ・山本祥平 ・芝浦工業大学大学 3年 ・サイボウズ・ラボユース研究生 10期生 ・セキュリティ・キャンプでデータベースゼミが開講されていたことから、DBMSに興味を持つ 2
活動内容 ・RDBMS(Relational Database Management System) の学習 ・『Database Design and Implementation』で紹介され
ているJavaのプログラムを参考にC言語でRDBMSを 実装 Database Design and Implementation ( http://www.cs.bc.edu/~sciore/simpledb/ ) 3
プログラムの構成 File Manager : ファイル入出力を行う Buffer Manager : Buffer Pool(メモリ内で持つデータの集合)の
管理を行う Log Manager : Logの書き込みを行う Transaction Manager ◦ Recovery Manager : Logの読み書きを行う。また、Logを用いて クラッシュリカバリを行う ◦ (Concurrency Manager : トランザクションの同時実行制御を行 う) Table Manager : 登録されるテーブルとフィールドの情報の管 理を行う Table Iterator : システムのファイルに保存されるTableの情報 に対し、参照・変更・追加・削除 File Manager Buffer Manager Log Manager Transaction Manager Table Manager / Table Iterator ユーザ テーブルに対する処理 トランザクションの 開始・終了 4
実装したLoggingの手法 Undo Logging : リカバリ時に、未完了のトランザクションのUndoのみを行うLoggingの手法 ・値の変更を行う際のディスクへの書き込み順序 1. Log FileにUpdate Logを書き込む
2. DB本体の値の変更を書き込む 3. Log Fileに変更を行ったトランザクションのCommit Logを書き込む 古い値 Log File DB本体 ・クラッシュ後とその際のリカバリ後のディスク 古い値 DB本体 クラッシュ後 リカバリ後 (ディスクへの書き込みが 無いときにクラッシュする) なにもしない 5
・クラッシュ後とその際のリカバリ後のディスク(続き) Update Log 古い値 Log File DB本体 古い値 古い値 DB本体
クラッシュ後 リカバリ後 Undoする Update Log 古い値 新しい値 Log File DB本体 新しい値 古い値 DB本体 Undoする Update Log Commit Log 新しい値 Log File DB本体 新しい値 DB本体 なにもしない (Update Logがディス クに書き込まれた後 にクラッシュする) (新しい値がディスク に書き込まれた後に クラッシュする) (Commit Logがディス クに書き込まれた後 にクラッシュする) 6
実行結果① ・insert ・update ・delete insert update delete insert 7
実行例② ・rollback (変更を加えたトランザクションをcommitではなく、rollbackで終了させると、 テーブルがそのトランザクション開始前の状態に戻っていることが確認できる) 8
実行結果③ ・リカバリ機能の確認 (変更を加えたトランザクションをcommitせず終了) (DBを起動し直し、commitしていないトランザクションの開始前の 状態に戻っていることが確認できる) 9
まとめ ・DBMSを学びながら、C言語で実装をした ◦ (最終的にできるようになったDBの操作の列挙 update/insert/print table/rollback/commit) ・大きなプログラムを実装する上で必要なコードの書き方を知ることができた ・これから ◦ トランザクションに関わる研究に触れたい
◦ 並行性制御(Concurrency Control)を持ったDBを実装したい 10 このような貴重な機会を頂きありがとうございました。