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

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

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

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

Q&A

解決済

1回答

13436閲覧

主キーの値を自動で設定してもらいたい

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

0グッド

0クリップ

投稿2015/10/31 10:42

MySQLを使っていて、たとえば以下のようなテーブルがあります。

lang

1CREATE TABLE body.artists 2( 3 artist_id INT NOT NULL, 4 artist_name CHAR(200), 5 description TEXT, 6 CONSTRAINT PRIMARY KEY (artist_id) 7);

このテーブルにレコードを追加するときに値を3カラム分指定しないといとエラーになります。
主キーのartist_idをinsertの時に指定するのではなく自動で連番にしてもらいたいのですが、どのように設定すれば良いのでしょうか?

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

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

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

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

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

guest

回答1

0

ベストアンサー

オートインクリメントで実現できます。
https://dev.mysql.com/doc/refman/5.6/ja/example-auto-increment.html


last_insert_id()関数について

last_insert_id()関数にFROM句は不要です。

公式のリファレンスによると、引数なしのlast_insert_id()の戻り値は

最近実行された INSERT ステートメントの結果として、最初に自動的に生成され、正常に AUTO_INCREMENT カラムに挿入された値を表す 64 ビット値

だからです。
https://dev.mysql.com/doc/refman/5.6/ja/information-functions.html#function_last-insert-id

なにやら難しいことを言っていますが、要するに
「最後に実行されたINSERT文で挿入されたレコードのうち、
(レコードが複数ある場合は)最初に挿入されたレコードのオートインクリメント値」
が返却されるわけで、テーブルを指定することができないためです。

sql

1mysql> CREATE TABLE sample1 (id INT PRIMARY KEY AUTO_INCREMENT); 2Query OK, 0 rows affected (0.01 sec) 3 4# sample2テーブルはオートインクリメントを11から開始 5mysql> CREATE TABLE sample2 (id INT PRIMARY KEY AUTO_INCREMENT) AUTO_INCREMENT = 11; 6Query OK, 0 rows affected (0.01 sec) 7 8 9mysql> INSERT INTO sample1 VALUES (); 10Query OK, 1 row affected (0.01 sec) 11 12mysql> INSERT INTO sample2 VALUES (); 13Query OK, 1 row affected (0.00 sec) 14 15 16# "FROM sample1"を付けても、返却されるのは最後にインサートしたsample2テーブルのオートインクリメント値 17mysql> SELECT last_insert_id() FROM sample1; 18+------------------+ 19| last_insert_id() | 20+------------------+ 21| 11 | 22+------------------+ 231 row in set (0.00 sec) 24 25mysql> SELECT last_insert_id(); 26+------------------+ 27| last_insert_id() | 28+------------------+ 29| 11 | 30+------------------+ 311 row in set (0.00 sec)

加えて、FROM句を付けると、指定したテーブルに格納されているレコードの数だけ、結果セットの行が返ってしまいます。

sql

1mysql> INSERT INTO sample1 VALUES (), (), (); 2Query OK, 3 rows affected (0.00 sec) 3Records: 3 Duplicates: 0 Warnings: 0 4 5mysql> SELECT last_insert_id() FROM sample1; 6+------------------+ 7| last_insert_id() | 8+------------------+ 9| 2 | 10| 2 | 11| 2 | 12| 2 | 13+------------------+ 144 rows in set (0.00 sec) 15 16mysql> SELECT last_insert_id(); 17+------------------+ 18| last_insert_id() | 19+------------------+ 20| 2 | 21+------------------+ 221 row in set (0.00 sec)

投稿2015/10/31 10:48

編集2015/10/31 11:41
KiyoshiMotoki

総合スコア4791

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

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

Ken.sakanakana

2015/10/31 10:59

そして、自動発行された番号を取得できます! select last_insert_id() from body.artists; PHPでPDOお使いでしたら、簡単に取得できます~ $id = $dbh->lastInsertId(); この仕組みはパラレルに大量にクエリが発行されている状況でも、必ず自身のコネクションで実行された直前の値が取得できます。ご参考まで。
KiyoshiMotoki

2015/10/31 11:42

Ken.sakanakana様、コメントありがとうございます。 last_insert_id()関数の使用方法について気になる点がございましたので、 回答のほうに追記させていただきました。
Ken.sakanakana

2015/10/31 16:40

ここまで詳しく書いて頂いてありがとうございます!これで少しでも同じ悩みの方が、この投稿をみて躓かないようになれば良いですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問