第3回 Ruby on Rails“シンプル”モデリング技法

太田 哲也
株式会社Cuon

2008/12/8

シンプル&スピーディの落とし穴に注意

 これらの設計技法を使用すると、シンプルかつスピーディで直感的なモデリングが可能だ。設計者としてはこのスピード感は非常に楽しいものであり、それを体感してしまうとついつい多用してしまいがちである。しかし、その一方でリソース部分での効率の悪さが気になってしまう。

 今回紹介した画像クラスの例でリソース的な効率の悪さを説明しよう。

  • type
  • parent_id
  • parent type

という、本来必要ではない3つのカラムが追加されている。

 このように1テーブルに役割を集約し過ぎているため、データベースの物理設計/論理設計やSQL文の記述時に、実行パフォーマンスへの配慮が必要となってくる。

 これらのデメリットは、物的リソースの進化が著しい昨今ではそこまで神経質になる必要はないのかもしれない。

 しかし、実際に利用するユーザーにとって一番重要なことは、「モデリングが美しい」ことではなく「使っていてストレスがない」ことだ。

 凝ったモデリングを行い、実際に動作させていく過程はエンジニアにとって非常に楽しいプロセスである。しかし、バランス感覚を失わないことを常に心掛け、くれぐれも“やり過ぎ”にならないように注意していくことが最も重要だろう(筆者もまだまだ勉強中の身である)。

2/2
 

Index
Ruby on Rails“シンプル”モデリング技法
  Page1
単一テーブル継承によるシンプルなテーブル定義
ポリモーフィック関連による集約された関連性
Page2
シンプル&スピーディの落とし穴に注意
RoRでCGMサイト構築虎の巻

 Ruby/Rails関連記事
プログラミングは人生だ
まつもと ゆきひろのコーディング天国
 ときにプログラミングはスポーツであり、ときにプログラミングは創造である。楽しいプログラミングは人生をより実りあるものにしてくれる
生産性を向上させるRuby向け統合開発環境カタログ
Ruby on Rails 2.0も強力サポート
 生産性が高いと評判のプログラミング言語「Ruby」。統合開発環境を整えることで、さらに効率的なプログラミングが可能になる
かんたんAjax開発をするためのRailsの基礎知識
Ruby on RailsのRJSでかんたんAjax開発(前編)
 実はAjaxアプリケーション開発はあなたが思うよりも簡単です。まずはRuby on Railsの基礎知識から学びましょう
Praggerとnetpbmで作る画像→AA変換ツール
Rubyを使って何か面白いものを作ってみよう!
 一般的な画像をアスキーアートに変換するツールを作ってみる。さらに出力にバリエーションを持たせてみよう
コードリーディングを始めよう
Railsコードリーディング〜scaffoldのその先へ〜(1)
 優れたプログラマはコードを書くのと同じくらい、読みこなす。優れたコードを読むことで自身のスキルも上達するのだ
  Coding Edgeフォーラムフィード  2.01.00.91


Coding Edge フォーラム 新着記事
@ITメールマガジン 新着情報やスタッフのコラムがメールで届きます(無料)

注目のテーマ

>

Coding Edge 記事ランキング

本日 月間