SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。
Q&A
3回答
3811閲覧
総合スコア29
0グッド
0クリップ
投稿2017/09/07 04:18
0
SQLでカラムを挿入する際に、 AUTO_INCREMENT PRIMARY KEYを指定するのと、 AUTO_INCREMENTを指定するのでは違いはありますか?
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
質問へのコメント
回答3件
実用上そんなことをする人がいるのかは知りませんが、PRIMARY KEYと別の列にAUTO_INCREMENTをかけることも可能です。
PRIMARY KEY
AUTO_INCREMENT
テーブルごとに存在できる AUTO_INCREMENT カラムは 1 つだけです。このカラムはインデックス付きである必要があり、(後略)
(MySQL 5.6 CREATE TABLE 構文より)
投稿2017/09/07 04:29
総合スコア145121
AUTO_INCREMENTの意義はレコードごとにユニークな数値を割り当てて 任意のレコードを一意に抽出することができることです。 つまりそれはPRIMARY KEYが本来すべきことなので 併用する場合が多いのです。 従ってユニークが重要なためAUTO_INCREMENTに連番的な採番を 期待してはいけません
投稿2017/09/07 06:08
総合スコア114572
そのカラムを、サロゲートキーの用途として使用するなら、PRIMARY KEY指定しておいた方が、DBMSが暗黙的に使用する場合でのレスポンスの向上に期待できます。
既にナチュラルキーがプライマリーキーとして設定されていて追加するという場合は、uniqueインデックスにしておけば類似的な効果が得られるかもしれません。
何にしても、目的を明確にされた方が、良い回答が得られると思いますよ。
投稿2017/09/07 05:30
総合スコア25138
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
まだベストアンサーが選ばれていません
アカウントをお持ちの方はログイン
15分調べてもわからないことはteratailで質問しよう!
ただいまの回答率85.50%
質問をまとめることで思考を整理して素早く解決
テンプレート機能で簡単に質問をまとめる
MySQL AUTO_INCREMENT PRIMARY KEYとAUTO_INCREMENTの違い
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。