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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

1回答

1611閲覧

MySQLで一意制約を設けた新規カラムに重複データのある既存カラムのデータをコピーしてUPDATEしたい

milkman4

総合スコア31

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

0クリップ

投稿2017/02/08 05:32

編集2017/02/08 05:33

MySQL初心者です。
タイトルのとおり、MySQLで一意制約を設けた新規カラムに重複データのある既存カラムのデータをコピーしてUPDATEしたいです。

下記の[実施前状態]を[実施後状態]にしたいです。
重複データをコピーする際は末尾に連番を振るようにしたいです。
データパッチの実現方法をご教示いただけると大変幸いです。
よろしくお願い致します。

######実施前状態

  • テーブル定義

DESC USERS;

+-----------------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-----------------+-------------+------+-----+---------+----------------+ | id | varchar(50) | NO | PRI | | | | first_name | varchar(50) | YES | | | | +-----------------+-------------+------+-----+---------+----------------+
  • レコード

SELECT FIRST_NAME FROM USERS;

+---------------------+ | first_name | +---------------------+ | TAICHI | | MAKI | | KENJI | | TAICHI | | TAICHI | +---------------------+

######実施後状態

  • テーブル定義

DESC USERS;

+-----------------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-----------------+-------------+------+-----+---------+----------------+ | id | varchar(50) | NO | PRI | | | | first_name | varchar(50) | YES | | | | | nick_name | varchar(50) | YES | MUL | | | +-----------------+-------------+------+-----+---------+----------------+
  • レコード

SELECT FIRST_NAME, NICK_NAME FROM USERS;

+--------------------+---------------------+ | first_name | nick_name | +--------------------+---------------------+ | TAICHI | TAICHI | | MAKI | MAKI | | KENJI | KEINJI | | TAICHI | TAICHI_2 | | TAICHI | TAICHI_3 | +--------------------+---------------------+

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

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

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

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

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

guest

回答1

0

ベストアンサー

手順として

  • カラムを追加(ユニークにしない)
  • 該当カラムにユニークな値を投入
  • カラムにユニーク属性をつける

としてください

具体的にはこんな感じ
-元データ

SQL

1create table USERS(id int not null primary key,FIRST_NAME varchar(50)); 2insert into USERS(id,FIRST_NAME) values(1,'TAICHI'),(2,'MAKI'),(3,'KENJI'),(4,'TAICHI'),(5,'TAICHI'); 3
  • NICK_NAMEカラムを追加

SQL

1alter table USERS add NICK_NAME varchar(50) after FIRST_NAME;
  • NICK_NAMEカラムを更新

SQL

1update USERS as T1 2inner join (select id,( 3select count(*) +1 4from USERS as T3 5where T3.id < T2.id 6and T2.FIRST_NAME=T3.FIRST_NAME 7) as RANK 8from USERS as T2 9) as T4 on T4.id=T1.id 10set T1.NICK_NAME= 11case 12when T4.RANK=1 then FIRST_NAME 13else concat(FIRST_NAME,'_',T4.RANK) 14end; 15
  • NICK_NAMEカラムにユニーク属性をつける

SQL

1alter table USERS add unique(NICK_NAME) ;

投稿2017/02/08 06:49

編集2017/02/08 06:53
yambejp

総合スコア114769

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問