mysqlの主キー設定

WBOY
リリース: 2023-05-11 16:15:07
オリジナル
7276 人が閲覧しました

MySQL は、Web アプリケーションの開発で広く使用されているオープンソースのリレーショナル データベース管理システムです。 MySQL では、各データ テーブルに主キーが必要です。主キーは、データ行を識別し、一意に決定するために使用されます。主キーを正しく設定することでクエリ効率やデータの整合性を向上させることができますので、この記事ではMySQLの主キーの設定方法と注意点を紹介します。

1. MySQL 主キーの概念

主キーは、一意のデータ行を識別するために使用されるデータ列または属性の組み合わせのセットです。 MySQL では、主キーは 1 つ以上のカラムで構成でき、各カラムは一意である必要があり、NULL 値を含めることはできません。主キーは、データの整合性と一貫性を保証する制約です。

2. MySQL の主キーの設定方法

  1. テーブル作成時に主キーを設定します

MySQL では、主キーを設定できます。

CREATE TABLE 表名(
    列1 数据类型 PRIMARY KEY,
    列2 数据类型,
    列3 数据类型,
    ...
);
ログイン後にコピー

このうち、列 1 が主キー列で、データ型は数値、文字列などになります。主キーが複数の列で構成されている場合は、次のように PRIMARY KEY キーワードの後に​​これらの列の名前を追加できます。

CREATE TABLE 表名(
    列1 数据类型,
    列2 数据类型,
    列3 数据类型,
    PRIMARY KEY(列1,列2)
);
ログイン後にコピー
    #テーブル構造を変更して主キーを追加します
テーブルの作成後、ALTER TABLE ステートメントを使用して主キーを追加することもできます。構文は次のとおりです。

ALTER TABLE 表名 ADD PRIMARY KEY (列名);
ログイン後にコピー

主キーが複数の列で構成されている場合は、列名を括弧内にカンマで区切ってリストできます。

    自動増加主キーの設定
MySQL では、自動増加主キーを設定することもできます。テーブルの作成時に、主キー列のデータ型の後に AUTO_INCREMENT を追加するだけです。

CREATE TABLE 表名(
    主键列 数据类型 AUTO_INCREMENT,
    列2 数据类型,
    列3 数据类型,
    ...
);
ログイン後にコピー
このように、データが挿入されるたびに、主キー列の値が自動的に 1 ずつ増加します。こうして自己成長を遂げます。

3. MySQL の主キーに関する注意事項

    主キーは一意である必要があり、NULL 値を含めることはできません。データ挿入時の主キー列の値が既存データの主キーと重複する場合、挿入は失敗します。
  1. 主キーの設計では、実際のアプリケーション シナリオ、データの一意性と一貫性をより確実に確保する方法、クエリ効率を向上させる方法を考慮する必要があります。
  2. 主キーのデータ型は、データベース全体のパフォーマンスに大きな影響を与えます。通常は、整数型または短い文字列型を使用することをお勧めします。
  3. 結合主キーを設定できますが、結合主キーの順序に注意してください。主キーの順序は、インデックスとクエリの最適化の効率に影響します。
  4. 主キーの一意性チェックは特定のシステム リソースを占有するため、複雑なデータ テーブルを設計するときはこれを考慮する必要があります。
4. 概要

MySQL の主キーは、一意のデータ行を識別するために使用されるデータ制約であり、データの整合性と一貫性を保証できます。 MySQL では、テーブルの作成時またはテーブル構造の変更時に主キーを設定できます。実際のアプリケーションでは、主キーの設計では、実際のニーズとデータベースのパフォーマンスへの影響を考慮する必要があり、主キーを適切に設定すると、クエリの効率とデータの整合性が向上します。

以上がmysqlの主キー設定の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート