ホームページ >データベース >mysql チュートリアル >MySQL の特定の列に基づいてデータをグループ化する自動インクリメント フィールドを作成するにはどうすればよいですか?
MySQL での自動インクリメント フィールド グループ化
MySQL では、グループ化カラムに基づいてインクリメントする自動インクリメント フィールドを作成できます。グループ化されたデータの順序付けのため。
実装
MyISAM テーブルと BDB テーブルの場合、次のテーブル構造を利用できます:
CREATE TABLE foo ( id INT AUTO_INCREMENT NOT NULL, group_field INT NOT NULL, name VARCHAR(128), PRIMARY KEY(group_field, id) );
説明
この構造では、「id」列の自動インクリメント値は次の式で決定されます:
MAX(auto_increment_column) 1 WHERE prefix=given-prefix
この場合、「プレフィックス」は「group_field」列の値を表し、自動インクリメント計算用にデータを効果的にグループ化します。
例
次の表を考えてみましょう:
id | name | group_field |
---|---|---|
1 | test | 1 |
2 | test2 | 1 |
1 | test3 | 2 |
2 | test4 | 2 |
1 | test5 | 3 |
2 | test6 | 3 |
新しいレコードを挿入すると、各グループ内で「id」列が自動的に増加し、次の結果が得られます:
id | name | group_field |
---|---|---|
3 | test | 1 |
4 | test2 | 1 |
3 | test3 | 2 |
4 | test4 | 2 |
3 | test5 | 3 |
4 | test6 | 3 |
このグループ化動作は次のようになります。テーブル内のデータを整理したり並べ替えたりするのに役立ちます。
以上がMySQL の特定の列に基づいてデータをグループ化する自動インクリメント フィールドを作成するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。