質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

Q&A

解決済

1回答

1605閲覧

データの整合性とは?

退会済みユーザー

退会済みユーザー

総合スコア0

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

0グッド

0クリップ

投稿2016/10/05 12:19

データベースにおいて、整合性という言葉は何を意味しているのでしょうか?
「達人に学ぶDB設計徹底指南書」という本に以下のような記述がありました。

「データベースにおいては、データの整合性とパフォーマンスの間に強いトレードオフが存在します。つまり、整合性を高くしようとするとパフォーマンスが犠牲になり、パフォーマンスを追求すると整合性を犠牲にする、という二律背反の原則です。データベース設計とは、限られた予算制約の中で、両端の間の平衡点を見つけ出そうとする努力だと言っていいでしょう。」

http://www.graffe.jp/blog/490/
こちらのサイトによると、データベースの整合性とは「テーブル同士の関係性が整っている」ことを指すようです。
したがって、上の記述はテーブル同士の関係性が整っていることとパフォーマンスはトレードオフの関係である、と述べているわけですが、そうなのでしょうか?
テーブル同士の関係性が整っていれば、その分パフォーマンスはますのではないかと思ってしまうのですが、どうなのでしょうか?
回答お願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

テーブル同士の関係性が整っていれば、その分パフォーマンスはますのではないかと思ってしまうのですが、どうなのでしょうか?

私が見たDBは大抵設計で失敗していて、そのせいでレスポンスが悪くなっている物ばかりでした。全く同意します。

ただ、厳密に論理設計を詳細設計に落としていくとテーブルが細かくなりすぎるのも想像出来ます。副問合せや集計が過剰に行われるとレスポンスが悪化するのです。

レスポンスを高めるために、集計結果を親レコードに登録すると、子レコードのデータと情報の重複が起こり、整合性が崩れる場合があるのです。また、副問合せを避けるために、(この例は大したレスポンス改善にはなりませんが)”都道府県コード”と”都道府県”の項目があるような設計をすることがあります。著者はその辺か、もっと事例を経験しているのかもしれません。

データベース設計とは、限られた予算制約の中で、両端の間の平衡点を見つけ出そうとする努力だと言っていいでしょう。

そんなレベルのDBばかりであったらどんなにか幸せなことでしょう。

私は、その本の著者のベージを読んでました。内容がWebとほとんど同じっぽいので、読んでませんが間違いなく最高レベルのDB設計が学べるはずです。(機会があれば買いたい)

投稿2016/10/05 13:29

iwamoto_takaaki

総合スコア2883

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2016/10/05 14:17

回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問