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
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Kenta SEKINE
May 30, 2025
Technology
1
3.1k
コードの考古学 〜労務システムから発掘した成長の糧〜
Kenta SEKINE
May 30, 2025
Tweet
Share
Other Decks in Technology
See All in Technology
広告の効果検証を題材にした因果推論の精度検証について
zozotech
PRO
0
210
Cloud Runでコロプラが挑む 生成AI×ゲーム『神魔狩りのツクヨミ』の裏側
colopl
0
150
Ruby版 JSXのRuxが気になる
sansantech
PRO
0
170
制約が導く迷わない設計 〜 信頼性と運用性を両立するマイナンバー管理システムの実践 〜
bwkw
3
1.1k
モダンUIでフルサーバーレスなAIエージェントをAmplifyとCDKでサクッとデプロイしよう
minorun365
4
230
Oracle AI Database移行・アップグレード勉強会 - RAT活用編
oracle4engineer
PRO
0
110
Tebiki Engineering Team Deck
tebiki
0
24k
M&A 後の統合をどう進めるか ─ ナレッジワーク × Poetics が実践した組織とシステムの融合
kworkdev
PRO
1
520
生成AIと余白 〜開発スピードが向上した今、何に向き合う?〜
kakehashi
PRO
0
170
AIが実装する時代、人間は仕様と検証を設計する
gotalab555
1
620
予期せぬコストの急増を障害のように扱う――「コスト版ポストモーテム」の導入とその後の改善
muziyoshiz
1
2.1k
学生・新卒・ジュニアから目指すSRE
hiroyaonoe
2
770
Featured
See All Featured
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
67
Building a Scalable Design System with Sketch
lauravandoore
463
34k
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
460
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
320
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
Public Speaking Without Barfing On Your Shoes - THAT 2023
reverentgeek
1
310
Un-Boring Meetings
codingconduct
0
200
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
90
[SF Ruby Conf 2025] Rails X
palkan
1
760
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
58
50k
How GitHub (no longer) Works
holman
316
140k
Transcript
コードの考古学 〜労務システムから発掘した成長の糧〜 2025.05.29 Thu. 若手エンジニアが語るリアルな実例 「技術負債」との戦い方・「技術資産の活かし方」 @株式会社プレイドオフィス 関根 健太 SmartHR
プロダクトエンジニア
関根 健太(@Kenta) 株式会社 SmartHR プロダクトエンジニア 新卒で入社した SIer企業では、サーバーサイド・フロントエンド・ インフラなど幅広い領域を経験。 2024年に株式会社 SmartHRへ入社。現
在は労務プロダクトの開発に携わっている。趣味はバイク。
SmartHRの紹介
None
None
None
今日話すこと 1. 労務プロダクトで出会った複雑データモデルの謎 2. 実際に直面した 3つの技術的課題 3. 歴史的遺産から得た若手エンジニアの気づき 4. 困難な状況を成長機会に変える実践方法
1. 労務プロダクトで出会った 複雑データモデルの謎
開発に参画してから “バイテン” というワードをよく耳にするようになりました。
「バイテン …?」「売店 …?」
BiTemporal Data Model 有効時間 (データが現実世界で有効である期間) システム時間 (データがデータベースに格納された時間)
ID 役職 開始 終了 追加 削除 1 - 03/01 ∞
03/01 04/01 1 - 03/01 04/01 04/01 ∞ 1 部長 04/01 ∞ 04/01 ∞ id bitemporal_id position valid_from valid_to transaction_from transaction_to 1 1 - 03/01 ∞ 03/01 04/01 2 1 - 03/01 04/01 04/01 ∞ 3 1 部長 04/01 ∞ 04/01 ∞ 例)03/01に登録された従業員が、 04/01に「部長」になった場合
むずい…🤯
なぜこんな複雑な構造なんだ …? 本当に必要 …?
履歴を管理するためには必要! 理解するしかない!
2. 実際に直面した 3つの 技術的課題
2-1. 複雑な履歴管理システム • BiTemporal Data Model • 複雑性が増し、上記を使っていない開発よりも時間 がかかる
2-2. コードの意図を読み解く考古学的作業 • 複雑な条件分岐が存在するも、その意図は表面か らは読み取れない • 過去のドキュメントを掘り起こすことで、当時の意思 決定の背景が明らかに
2-3. フロントエンドの技術スタック混在 • FIXME/TODOコメントが示す「一時的」なはずの解 決策が恒久的実装となる現象 • jQuery/haml(過去)と React(現在)という異なる時 代の技術が共存する状態
3. 歴史的遺産から得た 若手エンジニアの気づき
3-1. 「悪いコード」ではなく「進化の証」 • 複雑なコードは最適だった過去の判断の結晶 • 制約に見える部分もプロダクト成功の証拠 • 批判より理解と尊重が次の進化を生む
3-2. 小さな改善の積み重ね • 1度の完璧な作り直しは幻想、現実的でない • 小さな範囲の確実な改善が着実な前進を生む • 「今できる最善のこと」の積み重ねが持続可能な改 善への道
3-3. ドキュメント化と知識共有の重要性 • 解読した複雑コードの知識を独占せず共有 • 実装背景の記録が将来の疑問解消に貢献 • 知識共有でチーム全体の対応力が向上
3-4. 拡張性を意識した設計 • 「一時的対応」が定着する現実を直視 • 短期実装も「 5年後の視点」で設計 • 将来への理解しやすさが持続可能な設計の鍵
4. 困難な状況を成長機会に変 える実践方法
4-1. 歴史的コードを批判せず「考古学者」のよ うに分析する • 実装の背景を様々な角度から発掘 • 技術とビジネス両面の文脈を理解 • 探求する姿勢が意思決定力を鍛える
4-2. 発見した知識を積極的に共有・文書化す る • 複雑な実装の背景をすぐにドキュメント化 • PRには「なぜこの実装か」の背景を明記 • 知識格差を減らし将来のエンジニアを助ける
4-3. 小さな改善を継続的に行う習慣をつける • ファイル編集時に「ついでの改善」を実践 • レビュー時も建設的な改善提案を積極的に • 頻繁に触れるコードから品質向上の好循環へ
最後に伝えたいこと • 古いコードの修正ではなく、プロダクトの歴史と未来 を理解する貴重な学びの場
最後に伝えたいこと • 過去の意思決定を理解することで、より良い判断が できるエンジニアに成長できる
最後に伝えたいこと • 未来の自分や仲間に感謝されるコードを目指し、 日々の小さな実践を積み重ねよう
共に未来のプロダクトを 築いていきましょう!