表についてのメモ » 履歴 » バージョン 6
健二 酒井, 2020/04/19 16:40
1 | 1 | 健二 酒井 | # 表についてのメモ |
---|---|---|---|
2 | 1 | 健二 酒井 | |
3 | 1 | 健二 酒井 | ## 概要 |
4 | 1 | 健二 酒井 | |
5 | 1 | 健二 酒井 | 表という形式について学んだり、気づいたり、考えたりしたことをまとめておく |
6 | 1 | 健二 酒井 | |
7 | 3 | 健二 酒井 | ## 表とは何だろう |
8 | 3 | 健二 酒井 | |
9 | 1 | 健二 酒井 | ### 表とは何だろう |
10 | 1 | 健二 酒井 | |
11 | 1 | 健二 酒井 | | 行\列 | 列1 | 列2 | 列3 | |
12 | 3 | 健二 酒井 | |:-:|:-:|:-:|:-:|:-:| |
13 | 1 | 健二 酒井 | | 行1 | 値 | 値 | 値 | |
14 | 1 | 健二 酒井 | | 行2 | 値 | 値 | 値 | |
15 | 1 | 健二 酒井 | | 行3 | 値 | 値 | 値 | |
16 | 1 | 健二 酒井 | | 行4 | 値 | 値 | 値 | |
17 | 1 | 健二 酒井 | |
18 | 1 | 健二 酒井 | 大体こんな形をしたもの。 |
19 | 1 | 健二 酒井 | 横方向の区切りを「列」、縦方向の区切りを「行」という。行と列を一つ決めたときに一つの値が決まるようになってる。 |
20 | 1 | 健二 酒井 | 例. あるときの家計簿(複式) |
21 | 1 | 健二 酒井 | |
22 | 3 | 健二 酒井 |  |
23 | 1 | 健二 酒井 | |
24 | 4 | 健二 酒井 | この例なら、1列目は日付(列)、2列目は科目_借(列)とかいったりする。 |
25 | 4 | 健二 酒井 | 最初の2020/1/4、食費、612、現金、612がの部分が1行目という。 |
26 | 4 | 健二 酒井 | |
27 | 1 | 健二 酒井 | ### マトリクスとテーブル |
28 | 4 | 健二 酒井 | |
29 | 4 | 健二 酒井 | 自分の定義でしかないけど、表を使うとき「マトリクス」としての利用と「テーブル」としての利用があるように思う。 |
30 | 5 | 健二 酒井 | どっかの定義がある訳ではないけど以下のようなイメージで考えている: |
31 | 3 | 健二 酒井 | |
32 | 5 | 健二 酒井 | - マトリクス 何らかの一覧として使って全体を眺めたい意図として使う |
33 | 5 | 健二 酒井 | - テーブル 特定の形式のデータを大量に保存する |
34 | 5 | 健二 酒井 | |
35 | 5 | 健二 酒井 | 意識的な違いだと思うので境界はあいまいだと思う。 |
36 | 5 | 健二 酒井 | 最初はマトリクスとして使っていたものが行が増えて行っていつまにかテーブルになってたこととかもありがち。 |
37 | 5 | 健二 酒井 | |
38 | 5 | 健二 酒井 | ただ、個人的には以下のような点が意識されると思う |
39 | 5 | 健二 酒井 | |
40 | 5 | 健二 酒井 | - 列に比べ行が増えていく使い方なのがテーブル |
41 | 5 | 健二 酒井 | - 行と列の項目がある意味「対等」なのがマトリクス、列が支配的だとテーブル |
42 | 5 | 健二 酒井 | - 2 x 2 とか 2 x 3とかの表で物事を分類するときに使うのはマトリクス。SWOT分析とか、そういう物。 |
43 | 5 | 健二 酒井 | - データの保存を目的にして使うならテーブル |
44 | 5 | 健二 酒井 | - データの閲覧を目的にして使うならマトリクス |
45 | 5 | 健二 酒井 | |
46 | 5 | 健二 酒井 | このメモは主としてテーブルについて語っていく予定。 |
47 | 5 | 健二 酒井 | ただ、マトリクスとしての表も味わい深いもの。経営とか戦略とかの領域ではマトリクスがよく使われる(勝手なイメージ)。 |
48 | 5 | 健二 酒井 | |
49 | 3 | 健二 酒井 | ### 活用例 |
50 | 3 | 健二 酒井 | |
51 | 3 | 健二 酒井 | ## テーブルの話 |
52 | 3 | 健二 酒井 | |
53 | 3 | 健二 酒井 | ### レコードと列 |
54 | 1 | 健二 酒井 | |
55 | 5 | 健二 酒井 | 上の家計簿の例を見てみよう。 |
56 | 5 | 健二 酒井 | 列は「日付」、「科目_借」、「金額_借_」、「科目_貸」、「金額_貸」と5つある。行は一杯ある。 |
57 | 5 | 健二 酒井 | この表を一行一行水平に切っていくと以下のように見る |
58 | 5 | 健二 酒井 | |
59 | 5 | 健二 酒井 | - 2020/1/4:食費:612:現金:612 |
60 | 5 | 健二 酒井 | |
61 | 5 | 健二 酒井 | こうした複の値を行単位でまとめたものを「レコード」とか言う。 |
62 | 5 | 健二 酒井 | 「テーブル」は「レコード」の寄せ集めとも考える。 |
63 | 5 | 健二 酒井 | |
64 | 5 | 健二 酒井 | ### 主キー |
65 | 5 | 健二 酒井 | |
66 | 5 | 健二 酒井 | 「テーブルのレコードを特定するための列を主キー」とかいう。「識別子(Identifier)」とか「ID」とか言う。 |
67 | 5 | 健二 酒井 | |
68 | 5 | 健二 酒井 | これだとよく分からんので例から見ていきましょう。例えば次のような表(テーブルとしてみる)を観察してみます。 |
69 | 5 | 健二 酒井 | 出勤した日とその日時を記録するための表です。 |
70 | 5 | 健二 酒井 | |
71 | 5 | 健二 酒井 | 出退勤表 |
72 | 5 | 健二 酒井 | |
73 | 5 | 健二 酒井 | | 日にち | 出勤 | 退勤 | 備考 | |
74 | 5 | 健二 酒井 | |:-:|:-:|:-:|:-| |
75 | 5 | 健二 酒井 | | 2020/04/01 | 08:57 | 18:50 | - | |
76 | 5 | 健二 酒井 | | 2020/04/02 | 08:54 | 18:10 | - | |
77 | 5 | 健二 酒井 | | 2020/04/03 | 09:43 | 18:50 | 電車遅延より遅刻 | |
78 | 5 | 健二 酒井 | | 2020/04/06 | 08:59 | 18:07 | - | |
79 | 5 | 健二 酒井 | | 2020/04/07 | 08:00 | 21:16 | - | |
80 | 5 | 健二 酒井 | | 2020/04/08 | 08:59 | 20:20 | - | |
81 | 5 | 健二 酒井 | |
82 | 5 | 健二 酒井 | 一つのレコードを見ることでどの日にどれぐらい働いたかを見られる。 |
83 | 5 | 健二 酒井 | |
84 | 5 | 健二 酒井 | ここでは「主キー」は「日にち」の列になります。 |
85 | 5 | 健二 酒井 | 「日にち」さえ指定してしまえば、レコードが特定できます。 |
86 | 5 | 健二 酒井 | 逆に「出勤」は「主キー」となりえません。例えば6日と8日の「出勤」は同じ値になっています。 |
87 | 5 | 健二 酒井 | 『「出勤」が08:59のレコード』と言うと2つ候補があるけど、『「日にち」が2020/04/06」のレコード』というと2つとありません。 |
88 | 5 | 健二 酒井 | |
89 | 5 | 健二 酒井 | こんな具合にその列の値さえ指定するとどのレコードかが一つに定まるのが「主キー」です。 |
90 | 5 | 健二 酒井 | 「二つのレコード同じ値を持つことがない列」と言うところでしょうか。 |
91 | 5 | 健二 酒井 | |
92 | 5 | 健二 酒井 | 「日にちがこれで、出勤があれで、退勤が…」と全ての値を指定しなくてよくなるのでデータを見つけるのが楽になります。 |
93 | 6 | 健二 酒井 | |
94 | 6 | 健二 酒井 | ### ID・代理キー |
95 | 6 | 健二 酒井 | |
96 | 6 | 健二 酒井 | 例えば、仕事によっては一日に2回出退勤することもあるかもしれません。 |
97 | 6 | 健二 酒井 | そんな場合には「日にち」では主キーの役割をこなせません。 |
98 | 6 | 健二 酒井 | こんなことに対処するための「レコードを特定するための専用の列」を作ったりします。その列の値は他の役割を持ちませ、また持たせません。 |
99 | 6 | 健二 酒井 | レコードを区別するためだけの列です。そういったものを「ID(列)」とか「代理キー」とか言ったりします。 |
100 | 6 | 健二 酒井 | |
101 | 6 | 健二 酒井 | ### レコードの順番と主キー |
102 | 6 | 健二 酒井 | |
103 | 6 | 健二 酒井 | ## 複数のテーブルを扱う |
104 | 6 | 健二 酒井 | |
105 | 6 | 健二 酒井 | ### 紐づく |
106 | 6 | 健二 酒井 | |
107 | 6 | 健二 酒井 | ### マスターとトランザクション |
108 | 6 | 健二 酒井 | |
109 | 6 | 健二 酒井 | ## テーブルの分割:正規化の話 |
110 | 6 | 健二 酒井 | |
111 | 6 | 健二 酒井 | ## テーブルの分割:クラス継承の話 |
112 | 6 | 健二 酒井 | |
113 | 6 | 健二 酒井 | ### 参考 |
114 | 6 | 健二 酒井 | |
115 | 6 | 健二 酒井 | - エンタープライズアプリケーションアーキテクチャパターン / マーティン・ファウラー |
116 | 6 | 健二 酒井 | |
117 | 6 | 健二 酒井 | ## 性能を考える |
118 | 6 | 健二 酒井 | |
119 | 6 | 健二 酒井 | ### データの容量 |
120 | 6 | 健二 酒井 | |
121 | 6 | 健二 酒井 | ### 探しだす速さ |
122 | 6 | 健二 酒井 | |
123 | 6 | 健二 酒井 | ### 記録の速さ |
124 | 6 | 健二 酒井 | |
125 | 6 | 健二 酒井 | ## 機能を考える |
126 | 6 | 健二 酒井 | |
127 | 6 | 健二 酒井 | ### データの正しさ |
128 | 6 | 健二 酒井 | |
129 | 6 | 健二 酒井 | ### やわらかさ |
130 | 6 | 健二 酒井 | |
131 | 6 | 健二 酒井 | ### 見やすさ |
132 | 6 | 健二 酒井 | |
133 | 6 | 健二 酒井 | ## RDBから考えるテーブルの大事なこと |