MySQL シーケンス AUTO_INCREMENT の詳細な説明とサンプルコード MySQL シーケンスは、1、2、3、... という整数のセットです。データ テーブルには自動増分主キー フィールドを 1 つしか持てないため、他のフィールドの自動増分を実現するには、MySQL シーケンスを使用できます。 この章では、MySQL シーケンスの使用方法を紹介します。 AUTO_INCREMENTの使用 MySQL でシーケンスを使用する最も簡単な方法は、MySQL AUTO_INCREMENT を使用して列を定義することです。 例 次の例では、insequent という名前のデータ テーブルを作成します。insequent の id は、値を指定しなくても自動的に増加します。 mysql> CREATE TABLE 昆虫 -> ( -> id INT UNSIGNED NOT NULL AUTO_INCREMENT、 -> 主キー (id)、 -> name VARCHAR(30) NOT NULL, # 昆虫の種類 -> date DATE NOT NULL、# 収集日 -> origin VARCHAR(30) NOT NULL # 収集場所 ); クエリは正常、影響を受けた行は 0 行 (0.02 秒) mysql> INSERT INTO 昆虫 (id,name,date,origin) 値 -> (NULL,'イエバエ','2001-09-10','キッチン'), -> (NULL,'ヤスデ','2001-09-10','車道'), -> (NULL,'バッタ','2001-09-10','前庭'); クエリは正常、3 行が影響を受けました (0.02 秒) 記録: 3 重複: 0 警告: 0 mysql> SELECT * FROM 昆虫 ORDER BY id; +----+-------------+-------------+-------------+ | ID | 名前 | 日付 | 出典 | +----+-------------+-------------+-------------+ | 1 | イエバエ | 2001-09-10 | キッチン | | 2 | ヤスデ | 2001-09-10 | 車道 | | 3 | バッタ | 2001-09-10 | 前庭 | +----+-------------+-------------+-------------+ セット内の 3 行 (0.00 秒) AUTO_INCREMENT値を取得する MySQL クライアントでは、SQL の LAST_INSERT_ID() 関数を使用して、テーブルに挿入された最後の自動インクリメント列の値を取得できます。 最後に挿入されたテーブルの自動インクリメント列の値を取得するための対応する関数も PHP または PERL スクリプトに用意されています。 PERLの例 AUTO_INCREMENT の値を取得するには、mysql_insertid 属性を使用します。 以下に例を示します。 $dbh->do ("INSERT INTO 昆虫 (名前、日付、起源) VALUES('moth','2001-09-14','windowsill')"); 私の$seq = $dbh->{mysql_insertid}; PHPの例 PHP は、mysql_insert_id() 関数を使用して、実行された挿入 SQL ステートメント内の AUTO_INCREMENT 列の値を取得します。 mysql_query ("INSERT INTO 昆虫 (名前、日付、起源) VALUES('moth','2001-09-14','windowsill')", $conn_id); $seq = mysql_insert_id ($conn_id); リセットシーケンス テーブル内の複数のレコードを削除し、残りのデータの AUTO_INCREMENT 列を再配置する場合は、自動増分列を削除してから再度追加することでこれを実行できます。 ただし、この操作は慎重に実行する必要があります。レコードの削除中に新しいレコードが追加されると、データの混乱が発生する可能性があります。操作は以下のとおりです。 mysql> ALTER TABLE 昆虫 DROP id; mysql> ALTER TABLE 昆虫 -> ADD id INT UNSIGNED NOT NULL AUTO_INCREMENT FIRST、 -> 主キー (id) を追加します。 シーケンスの開始値を設定する 通常、シーケンスの開始値は 1 ですが、開始値 100 を指定する必要がある場合は、次のステートメントで指定できます。 mysql> CREATE TABLE 昆虫 -> ( -> id INT UNSIGNED NOT NULL AUTO_INCREMENT = 100, -> 主キー (id)、 -> name VARCHAR(30) NOT NULL, # 昆虫の種類 -> date DATE NOT NULL、# 収集日 -> origin VARCHAR(30) NOT NULL # 収集場所 ); または、テーブルが正常に作成された後に、次のステートメントを使用してこれを実行することもできます。 mysql> ALTER TABLE t AUTO_INCREMENT = 100; 読んでいただきありがとうございます。お役に立てれば幸いです。このサイトをサポートしていただきありがとうございます。 以下もご興味があるかもしれません:
|
>>: Dockerのインストール方法とDockerの4つのネットワークモードの詳細説明
1. transform 属性を使用して、画像を拡大せずに表示します (パスの問題は必要に応じて修正...
1. サーバーのセットアップリモート リポジトリは実際にはローカル リポジトリと何ら変わりなく、純粋...
インストール前の作業: VMware Workstation がインストールされていることを確認し、...
目次ライフサイクルを理解する理由ライフサイクルとはライフサイクルフック関数作成され、マウントされたフ...
1: openssl とは何ですか? その機能は何ですか?適用シナリオは何ですか? Baidu 百科...
目次1. はじめに2. 詳しい説明2.1、非同期2.1.1. 関数はPromise以外のオブジェクト...
この記事の例では、JavaScriptでデジタル時計効果を実装するための具体的なコードを参考までに共...
CSS Sprite は、CSS スプライトとも呼ばれ、画像結合技術です。この方法は、複数の小さなア...
導入悠宇希の原文です。 vite は Vue CLI に似ています。vite も、基本的なプロジェク...
背景mysql.slow_log からスロー クエリ ログを取得するのは遅く、テーブルは csv テ...
1. ElasticSearch とは何ですか? Elasticsearch も Java で開発さ...
1. ミドルウェアの紹介1. 基本概念ElasticSearch は Lucene をベースにした検...
少し前にTik Tokを見ていて、フォローするときのボタンアニメーションがとても美しいと思ったのと、...
序文Dockerを使ってHadoopクラスタを起動するたびに、ネットワークカードの再バインド、IPの...
VMware Toolsをインストールすると、仮想マシンホスト間で①テキストをコピーして貼り付けるこ...