ITパスポート試験 用語辞典

しゅきー
主キー
【Primary Key】
関係データベースのテーブル(表)ごとに設定され、テーブルの中である一つの行を一意に特定できる値を保持する属性(列)、または属性の組合せのこと。主キー列には一意性制約とNOT NULL制約が課される。
↓ 用語データを見る
分野:
分野:テクノロジ系
中分類:データベース
小分類:データベース設計
出題歴:
H21年秋期問84 H22年春期問83
H23年特別問72 H26年春期問64
重要度:
(Wikipedia 主キーより)

主キー(しゅキー、英語:primary key)とは、リレーショナルデータベースにおいて、組(レコード)の識別子として利用するのにもっとも好ましいものとして、リレーション(テーブル)毎にただ一つ設計者により選択・定義された候補キーをいう。つまり、リレーションに格納されたレコードを一意に識別するための属性(列、アトリビュート)またはその集合のうち、そのために通常利用されるべき特定の一つをいう。

リレーショナルデータベース管理システム(RDBMS)やミドルウェア、アプリケーションなどでレコードの識別子が必要な場合、主キーがそのために使われることが多い。ただ、そうしなければならない必然性はなく、他の候補キーを使っても良い。したがって、主キーの理論上の意義は大きくないが、実務上は、そのわかりやすさなどから広く使われている概念である。
ただし、主キーにはNULLの存在が許されないが、候補キーには許されるという差があるとする立場もある(レコードの追加、更新時の制約として主キーを考える場合、一意性制約にNOT NULL制約を加えたものが主キー制約であると考えることができる)。

リレーションに存在する候補キーが一つであるときは、その候補キーが当然に主キーとなる。

なお、主キーでない候補キーは代理キー(alternate key)という。

主キーと代理キーの例

  • 生徒名簿(生徒番号, 生徒名, クラス)というリレーションの場合、生徒番号が主キーになり得る。同姓同名を考慮すると、生徒番号は唯一の候補キーであるから、代理キー はない。
  • 市町村(市町村ID, 市町村名, 都道府県名)というリレーションの場合、市町村ID と {都道府県名, 市町村名} が候補キーであり、いずれかが主キーになり得る。例えば、市町村ID を主キーにした場合、{都道府県名, 市町村名} は代理キーとなる。

主キーの選択

候補キーが複数あるとき、組を識別するという機能においてそれらの間に差異はないから、主キーにどれを選んでも論理的には問題がない。しかし実用上は、以下のような指針に従って選択するのがよい。

  • 主キーは検索のキーとして利用されたり、他のリレーションに参照のために格納されたりする可能性が高いため、できる限りデータ量の小さい方がよい。よって、複合キーはあまり適さない。データ量が多いキーしかない場合は、人工キー(後述)を設けることがある。
  • 主キーは検索のキーとして利用されるほか、電話や書面で伝達されることも多いのでdate=2011年9月|、簡潔に間違いなく伝達できる形式であるのが望ましい。一定の桁数のアルファベットや数字からなる主キーは、この点でも優れている。
  • 主キーはそのリレーションの外部(他のリレーションや、外部システム、ユーザなど)で識別子として利用される可能性が高いため、不変(immutable)であるべきである。つまり、更新がかからない項目がよい。例えば、他のリレーションで主キーを使用していた場合、主キーを更新すると他のリレーションの値(外部キー)も同時に更新しなければならなくなる。また、外部システムなどに所在するデータについては、このような更新が不可能なことがありうる。なお、人工キーは通常、それ自体に意味を持たないため、不変であるから、この問題も避けることができる。

主キーの設定

リレーション(テーブル)作成の際に、以下のようにSQLステートメントを記述して主キーを設定する。

 1. テーブル制約として定義する方法:

 2. 列制約として定義する方法:

 3. 複数の列に対して主キーを設定する方法:

 4. ALTER TABLE ステートメントを使うこともできる。

人工キーと自然キー

連番(順序・シーケンスとも呼ばれる)のように、一意性を確保するためだけにシステム内部で生成され、利用者が関知しない情報を格納する属性からなる主キーを人工キー、人為キー(artificial key)ないし別名キー(alias key)、代替キー(surrogate key)などといい、逆に、システム外部から格納すべきものとして与えられる情報を格納する属性からなる主キーを自然キー(natural key)ということがある。

利用者が関知しないという点について、エドガー・F・コッドによる定義では、人工キーの値が、利用者に提示されたり、利用者の発行する問い合わせのキーとなったりしないことが要求されている。しかし一般には、単に利用者の意向と無関係にシステムが生成するものを広く人工キーと呼ぶことも多い。

設計されたリレーションの属性に候補キーがない場合には、人工キーを付け加えざるを得ないが(前述の生徒名簿リレーションに生徒番号がなかった場合を考えよ)、そうでない場合にも人工キーを付け加えるべきか、そのようなことは避けて自然キーを使うべきかについては議論がある。自然キーには、リレーションに余計な属性を付け加える必要がないという利点があるが、複合キーになりがちであるし、外部の状況が変化すれば変更も必要となるから、前述の指針からみると望ましくない選択となることがありうる。人工キーの利点・欠点はその逆である。実際には、これらの得失のバランスは、場合により異なるから、ケース・バイ・ケースで判断すべきであろう。

出題例

関係データベースに関する記述中のa,bに入れる字句の適切な組合せはどれか。

関係データベースにおいて,レコード(行)を一意に識別するための情報をaと言い,表と表を特定のbで関連付けることもできる。

[出典]ITパスポート 平成23年春期 問72

72.gif
正解 

「データベース設計」の用語

「データベース」の他の分野

「テクノロジ系」の他のカテゴリ

このページのWikipediaよりの記事は、ウィキペディアの「主キー」(改訂履歴)の記事を複製、再配布したものにあたり、このページ内の該当部分はクリエイティブ・コモンズ 表示 - 継承 3.0 非移植 ライセンスの下 に提供されています。


Pagetop