
No.3ベストアンサー
- 回答日時:
#2回答者です。
「違い」について、追記します。
「違い」は、「表の定義の中で指定する」のと、「インデクスの定義で指定する」といったところです。表定義で指定すれば、DDLを逆生成した場合など、「インデクスの定義がどうなっているか?」といった手間が省けます。
その一方、表の定義そのものを変更するので、不慣れな場合はちょっと怖いかも。
一方、インデクス定義で作成する場合、表の定義自体はそのままなので、そういった不安はないと思います。
add constraint は、表の持つデータの正当性を保障するため制約するも
の。表自身の定義の一部となる。
create index は、検索等を効率よく行うため、データにインデックスを
つけるもの。unique はインデックス付けする際のデータの特徴をあらわ
すもので、表自身とは別に定義されるもの。
機能的には同じような働きをするが、目的が違うと理解しました。
create unique index の unique は、たまたまデータがユニークという特
徴をもっているだけで、ユニークじゃないデータが発生した場合は、(この
ままでは登録できないので) unique を外すことになるということだと考え
ます。
ありがとうございました。
No.5
- 回答日時:
>create unique index の unique は、たまたまデータがユニークという特
>徴をもっているだけで、ユニークじゃないデータが発生した場合は、(この
>ままでは登録できないので) unique を外すことになるということだと考え
>ます。
それは違います。
create unique indexは、一意性を保つためにも使用されます。
create tableでのunique指定は、RDBMSによっては実装されていないものもあります。
「uniqueで定義できなければ、uniqueを外す」というのは、テーブル設計に失敗しているということになります。
SQLの標準化では、操作系SQLに比べ、定義系SQLは後回しになっており、各RDBMSで独自仕様が多く含まれる部分です。推測ですが、create tableのunique指定は後から標準SQLに追加されたのではないかと思います。
その一方で、create indexでのunique指定は、標準SQLには入っていなかったものの、商用RDBMSが出始めた頃から、多くのRDBMSに実装されていました。
そのため、古くからRDBMSを使っていた人は、create indexでunique指定することで重複禁止にする方法に慣れていると思います。
補足 ありがとうございます。
> 「uniqueで定義できなければ、uniqueを外す」というのは、テーブル設
> 計に失敗しているということになります。
おっしゃることはわかります。unique 制約のないデータに unique index を
作るということが、そもそも間違いなのでしょうね。
No.4
- 回答日時:
ERROR:...
を3回出して、検証されているようです。
それらのメッセージは、当然そのまま受け入れてください。
お問い合わせの2点の違いのほかに、次のキーワードの考え方がが混乱に輪を掛けているようです。
・ UNIQUE
・ レコードの重複
まず考えておかなければならないのは、この両者は、
両立しない
と言うことです。その結果一方を先に設定すると他方は設定できなくなります。要するに
設定の順番
が重要となります。
この考え方で、もう一度 ERROR:... を見直してみてください。
たとえば、3番目。
エラーの原因は、このとき既に重複したレコードを含んでいたわけです。
この重複したレコードの状態をすべてなくしてから実行してみてください。
alter table ... UNIQUE ...
は、成功します。
回答ありがとうございます。
質問のタイトル「constraint と index の違い」がまずかったと反省してい
ます。このタイトルだと最初にいただいた回答のとおりだと思います。
ただ、今回は unique constraint と unique index の違いがわからなかった
ため、質問させていただいたものでした。
unique というキーワードは、制約を課す constraint では本質的なもの、
効率化を図る index では補助的なものと理解しました。
No.2
- 回答日時:
重複エラーになって当然です。
前者は表に対し、一意性をRDBMS側で保証してもらう指定です。主要なRDBMSでは、一意性を保証するための実装方式として、内部的に重複禁止のインデクスを作成します。もし、インデクスがなければ、重複チェックのために全件サーチが必要になってしまいますからね。
後者は、利用者側でインデクスを明示的に指定する方法です。インデクスはデータの絞込み、ソート抑止などの性能面の効果と、UNIQUE指定することで、重複データの存在を許さないようにできます。
No.1
- 回答日時:
・ ADD CONSTRAINT はテーブルに制約を設けます。
この条件を満たさないレコードは、追加もされないし更新もされません。
つまり、違反するレコードは存在しないことが保証されます。
この場合、列 のペア(dist_id, zipcode)が重複することは許されません。
・ CREATE UNIQUE INDEX は、検索を速めるための機能です。
UNIQUE キーワードを使用した場合、インデックスを構成する列 (dist_id, zipcode)が重複すると、インデックスを作成しません。
つまりこのようなペアを持つ複数のレコードの存在は許されます。
この回答への補足
なるほど! と思ったのですが、PostgreSQL 8.1 で
create unique index し、列のペア(dist_id, zipcode) が重複する
データをインサートしてみたところ、
ERROR: duplicate key violates unique constraint "dist_id_zipcode_key"
となりました。
また、すでに重複するペアを持つテーブルで create unique index すると
ERROR: could not create unique index
DETAIL: Table contains duplicated values.
のようになり、インデックスが作成できませんでした。
alter table ... add constraint した場合は、
NOTICE: ALTER TABLE / ADD UNIQUE will create implicit index "dist_id_zipcode_key" for table "distributors"
ERROR: could not create unique index
DETAIL: Table contains duplicated values.
というエラーになりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL MYSQL エラー 2 2022/10/18 11:37
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- Ruby No route matches [GET] "/posts/5/destroy" 1 2022/03/24 13:00
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP php エラー 2 2022/10/23 16:43
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
列が存在しないと言われる
-
インデックスの削除と、インデ...
-
PostgreSQLの「not null」制約...
-
SQL における変数の宣言と代入...
-
CREATE INDEXはどういう時に使...
-
複数キーワードでのあいまい検索
-
カラムのデフォルト値に16進数
-
PostgreSQLで表結合+DELETEしたい
-
【マクロ】列を折りたたみ非表...
-
Excel 2019 のピボットテーブル...
-
エクセルVBAで5行目からオート...
-
「直需」の意味を教えてください
-
ACCESSのSQLで数値型に変換する...
-
『iPod nano』英語→日本語に直...
-
Accessでテーブル名やクエリ名...
-
Access97の不具合(?)
-
エクセルグラフの凡例スペース
-
ACCESSについて質問させ...
-
Accessでテーブルからテーブル...
-
Accessのリンクテーブルのパス...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
PostgreSQLで表結合+DELETEしたい
-
列が存在しないと言われる
-
長いSQL文を実行するには?
-
INSERTできるレコード数を制限...
-
0の除算
-
alter tableすると、処理が止ま...
-
SQLで特定データがNULLなら別デ...
-
DBから日付順に指定件数の削除...
-
constraint と index の違い
-
大量データを更新したら、処理...
-
動的に生成したカラムを使ったF...
-
SQLite:項目が存在しない場合の...
-
DB2 「既存カラムへのnot null...
-
powergres(postgres)にalter文...
-
INSERTできない
-
postgreSQLの日付を変数にする...
-
SQL における変数の宣言と代入...
-
PostgreSQLの「not null」制約...
-
インデックスの削除と、インデ...
-
UPDATE文について
おすすめ情報