エントリーの編集
![loading...](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/common/loading@2x.gif)
エントリーの編集は全ユーザーに共通の機能です。
必ずガイドラインを一読の上ご利用ください。
記事へのコメント0件
- 注目コメント
- 新着コメント
このエントリーにコメントしてみましょう。
注目コメント算出アルゴリズムの一部にLINEヤフー株式会社の「建設的コメント順位付けモデルAPI」を使用しています
![アプリのスクリーンショット](https://b.st-hatena.com/bdefb8944296a0957e54cebcfefc25c4dcff9f5f/images/v4/public/entry/app-screenshot.png)
- バナー広告なし
- ミュート機能あり
- ダークモード搭載
関連記事
2013-04-30
SQLアンチパターンの感想の続きです。ゴールデンウィーク中にどこまでいけるだろう。 テーブル設計の変... SQLアンチパターンの感想の続きです。ゴールデンウィーク中にどこまでいけるだろう。 テーブル設計の変更が起きると、それを使用するプログラムに大きな影響を与えることから、出来る限りテーブル設計の変更を避けようという意識が働く事が多い。よって、柔軟な設計にするため、より抽象度の高いテーブルを設計しようとする。ただそのデメリットも大きいというお話である。 抽象度を上げるためにここで行なっていることは、テーブル(エンティティ)自体に属性(アトリビュート)の属性名とその値(バリュー)のセットを格納する方法である。本書ではIssuesというテーブルを作っているが、属性値が存在せず、IssuesAttributesというテーブルに属性名と値が入っている。 動機として挙げられているのはサブタイプの実装である。サブタイプとはオブジェクト指向モデルでいうところのサブクラスとほぼ同じであり、メソッドを持っていな