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
ドメイン名の話 (データベース,SQL)
Search
tsuda.a
July 04, 2015
Programming
21
0
Share
ドメイン名の話 (データベース,SQL)
データベースのドメイン名の話
tsuda.a
July 04, 2015
More Decks by tsuda.a
See All by tsuda.a
マジカルインクリメントと指数表記
tsudaahr
0
240
バックアップしていますか?
tsudaahr
0
140
RDB以前のファイル設計の話でもしようか(ぇ
tsudaahr
0
150
NPUわからん
tsudaahr
0
200
計算量オーダーの話
tsudaahr
1
440
クラウド初学者が抱える不安について
tsudaahr
0
320
キューとは何か
tsudaahr
0
270
等幅は死んだ(ぇ
tsudaahr
0
130
いくら眺めてもエラーの理由がわからないコードについて
tsudaahr
0
210
Other Decks in Programming
See All in Programming
検索設計から 推論設計への重心移動と Recall-First Retrieval
po3rin
2
530
煩雑なSkills管理をSoC(関心の分離)により解決する――関心を分離し、プロンプトを部品として育てるためのOSSを作った話 / Solving Complex Skills Management Through SoC (Separation of Concerns)
nrslib
4
970
AI時代のエンジニアリングの原則 / Engineering Principles in the AI Era
haru860
0
490
Agentic Elixir
whatyouhide
0
350
瑠璃の宝石に学ぶ技術の声の聴き方 / 【劇場版】アニメから得た学びを発表会2026 #エンジニアニメ
mazrean
0
260
Programming with a DJ Controller — not vibe coding
m_seki
3
130
GoogleCloudとterraform完全に理解した
terisuke
1
110
Claude Codeをカスタムして自分だけのClaude Codeを作ろう
terisuke
0
140
ルールルルルルRubyの中身の予備知識 ── RubyKaigiの前に予習しなイカ?
ydah
1
190
10年分の技術的負債、完済へ ― Claude Code主導のAI駆動開発でスポーツブルを丸ごとリプレイスした話
takuya_houshima
0
2.6k
PHPで TLSのプロトコルを実装してみるをもう一度しゃべりたい
higaki_program
0
210
The Less-Told Story of Socket Timeouts
coe401_
3
440
Featured
See All Featured
A Soul's Torment
seathinner
6
2.7k
How to train your dragon (web standard)
notwaldorf
97
6.6k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
The Limits of Empathy - UXLibs8
cassininazir
1
310
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
770
RailsConf 2023
tenderlove
30
1.4k
How to build a perfect <img>
jonoalderson
1
5.4k
The SEO Collaboration Effect
kristinabergwall1
1
420
Building a Modern Day E-commerce SEO Strategy
aleyda
45
9k
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
120
GraphQLとの向き合い方2022年版
quramy
50
15k
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4k
Transcript
ドメインの話 LTDD #15 @tsuda_ahr
ドメインというと色々ありますが… 今回のドメインは、www.servername.com 、的なやつじゃないです。
昨年、某DB勉強会のハンズオンで、こんな ER 図を書きましたが
列名の命名方法で質問があったんですね。 なぜ「file_size」なのか。 「Size」じゃないのか?
ドメイン(定義域)という考え方がありまして。 列名はオブジェクト指向のプロパティやフィールドとはちょっと違う感じ。 列名 = 型、に近い。 この「型」のようなものを「ドメイン名」と呼ぶ。
ドメイン名の利点1: 自然結合 普通に結合 select * from TABLE_A inner join
TABLE_B on TABLE_A.key1 = TABLE_B.key1; こう書ける select * from TABLE_A natural join TABLE_B;
つまり 普通の結合の場合は、結合する列の対応を記述しないといけない。 自然結合の場合は、同名の列名は結合の対象と自動で判断する。 記述量が減るので、ちょっと便利。 ただ、自然結合は、同名の列名すべてと JOIN
するので使いづらい場合が多い。
ドメイン名の利点2: 自然結合を使わない場合でも! 同名の列は「結合の条件となり得る」と判断できる。 逆に、列名が違うもの同士の結合は結合してはならない、という暗黙の了解(=規約)を得るこ とができる。 (オブジェクト指向でいう「型の違う代入」と同等) こちらの利点が主力。
利点2の場合は、実は別の方法もある create domain 文 本当にデータ型を作る -- PostgreSQL の例 create
domain file_size as numeric(12); create table TABLE_A( key1 as varchar(10), size as file_size ); -- Oracle にはない模様
create domain の利点と欠点 型名(ドメイン名)による、列の生成が可能となる。 →命名規約というあやふやなものに依存しなくて済む。 他方、ドメイン名に頼って列名を自在に命名すると、自然結合が効かなくなる。 結合列の是非も列名からだけでは判定できないので、SQLの組立てが難しくなる場合が多い。
(ハンガリアン記法みたいですね)
まとめ 列名は、オブジェクト指向プログラミングのようにオブジェクト(=テーブル)単位で ユニークにするのではなく、スキーマ単位,あるいはもっと上位のレベルでユニークに するようにします。 列名は「変数名(プロパティ名)」ではなく、「型名」だと思うようにします。 つまり、同じ列名を持っているものは、みな同じ性質を持っていて、かつ、他のテーブルで 同名の列名がある場合には、その列との結合が可能であるように設計します。
しかし例えば同じ型(?)の列が必要な場合もあるので、そのあたりは臨機応変に。 例)自分の性別と恋愛対象の性別を、同一のテーブルに定義する場合とか。
ご清聴ありがとうございました。