mysqlで下記のAAAというテーブルからuniqueキー設定されている
BBBという列名をuniqueキーから解除することを考えています。
CCCもuniqueキーですが、CCCはuniqueのまま残します。
テーブル構造は下記の通りです。
CREATE TABLE `AAA` (
`id` char(5) NOT NULL COMMENT 'ID',
`BBB` char(3) NOT NULL COMMENT 'コード',
`CCC` varchar(50) NOT NULL COMMENT '名前',
PRIMARY KEY (`id`),
UNIQUE KEY `UK_AAA` (`BBB`,`CCC`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='AAA用'
まずは、下記sqlでindexを削除しました。
alter table `AAA` drop index UK_AAA ;
その後のテーブル構造は下記のようにUNIQUE KEY `UK_AAA`が消えました。
CREATE TABLE `AAA` (
`id` char(5) NOT NULL COMMENT 'ID',
`BBB` char(3) NOT NULL COMMENT 'コード',
`CCC` varchar(50) NOT NULL COMMENT '名前',
PRIMARY KEY (`id`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='AAA用'
そして次のsqlでBBBをuniqueに再び設定しようと試みました。
alter table `AAA` add unique (BBB);
しかし、ここで警告メッセージが出現しうまく反映されません。
[Err] 1062 - Duplicate entry '0' for key 'BBB'
自分でこの警告を調べてもわかりませんでした。
結果的にBBBがunique解除されればいいので、私が実施したsql手順
でなくても他に効率のいいやり方があればその方法をご教授ください。
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
>本題のuniqueをCCCだけに変更するやり方を教えていただけますか?
具体的には
CREATE TABLE `AAA` (
`id` char(5) NOT NULL PRIMARY KEY
,`BBB` char(3) NOT NULL
,`CCC` varchar(50) NOT NULL
,UNIQUE KEY `UK_AAA` (`BBB`,`CCC`)
);
INSERT IGNORE INTO `AAA`
VALUES('id001','xxx','test1'),('id002','xxx','test2'),('id003','yyy','test1'),('id004','xxx','test2')
とすると、BBBとCCCの組み合わせによって、id004のINSERTが拒否されます
その際BBBはxxx、CCCはtest1という同じ値を持っていてもINSERTできていることを理解してください
ここで、インデックスUK_AAAを外したとして、
ALTER TABLE `AAA` DROP INDEX `UK_AAA`;
あらたにBBBやCCCだけのユニークを作ろうとしても
すでにユニークでないデータがあるため処理できません。
ALTER TABLE `AAA` ADD UNIQUE`UK_AAA2`(`BBB`);
エラー:Duplicate entry 'xxx' for key 'UK_AAA2'
ALTER TABLE `AAA` ADD UNIQUE`UK_AAA3`(`CCC`);
エラー:Duplicate entry 'test1' for key 'UK_AAA3'
それぞれxxx、test1がダブってるから無理というエラー
データ投入後にあとからユニーク属性をつけるのであれば
ダブリデータを手動で削除したのち、ALTER TABLE してください
ちなみにCCCにダブリデータがあるかどうかのチェックはこんな感じ
SELECT `CCC` FROM `AAA` GROUP BY `CCC` HAVING COUNT(*)>1
No.1
- 回答日時:
>UNIQUE KEY `UK_AAA` (`BBB`,`CCC`)
というのはBBBとCCCの組み合わせがユニークということで
BBB、CCCがそれぞれユニークというわけではないということは理解していますか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL SHOW CREATE TABLE posts;これって何ですか? 3 2022/08/28 22:57
- SQL Server ACCESSで3ファイルを結合して、表を作成するやり方を教えて下さい。 17 2022/08/15 20:34
- Excel(エクセル) ¥マークを含むパスの処理について(マクロ、または関数) 2 2022/12/25 02:11
- SQL Server ACCESSで複数テーブルを結合して、リストを作る方法を教えてください。 2 2022/08/12 19:32
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQLサーバから、項目の属性(型...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
[MySQL] UNIQUE制約の値を更新...
-
select文のwhere句に配列を入れ...
-
SQLにて特定の文字を除いた検索...
-
selectした大量データをinsert...
-
エクセルの関数について教えて...
-
sqlで、600行あるテーブルを100...
-
MySQLのint型で001と表示する方...
-
VIEWの元のテーブルのindexって...
-
複数テーブルのGROUP BY の使い...
-
Unionした最後にGROUP BYを追加...
-
Access パラメータクエリをcsv...
-
LAST_INSERT_IDで同時にアクセ...
-
PL/SQLの変数について
-
[SQLServer] テーブル名からカ...
-
VMwareがCDドライブを認識する...
-
1対多結合で多を絞り込み条件と...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報
そのあたり曖昧に認識していました。
ありがとうございます。
本題のuniqueをCCCだけに変更するやり方を教えていただけますか?