1. PK (主キー制約)
1. 主キーとは何ですか?
主キーを理解する前に、まずキーワードとは何かを理解してください。
キーワード: テーブル内の一意のフィールド (例: A person's) ID番号と学籍番号です。テーブルには複数のキーワードを含めることができます。
主キーは、1 つ以上のキーワードの組み合わせです。テーブル全体に関する情報は、主キーを通じて取得できます。主キーとも呼ばれます。注文テーブルを例にとると、注文番号を通じて注文の荷受人名、製品情報、価格、その他の関連情報を取得できます。
注: キーワードは主キーである必要はありません。主キーはキーワードである必要があります。
特徴: 主キーは空であってはならず、一意であり、繰り返すことはできません。テーブルには主キーが 1 つだけあるか、主キーがなく、複数の主キーを持つことはできません。
2.主キーを設定するにはどうすればよいですか?
方法 1: テーブルの作成時に主キーを設定する
-- 建立User表 CREATE TABLE User( User_id int NOT NULL, User_name VARCHAR(20), User_pwd VARCHAR(18), -- 在这里设置id为主键 PRIMARY KEY(User_id) )
CREATE TABLE Users( -- 也可以在字段中直接设置主键 User_id int NOT NULL PRIMARY KEY, User_name VARCHAR(20), User_pwd VARCHAR(18) )
上記のどちらの方法でも、同じ効果を持つ主キーを作成できます。
方法 2: テーブル作成時に主キーを設定せず、テーブルに主キーを設定します
最初に主キーを設定せずにテーブルを作成します
CREATE TABLE User( User_id int NOT NULL, User_name VARCHAR(20), User_pwd VARCHAR(18) )
次に主キーを設定します
原則として、作成時にコードに PRIMARY KEY (User_id) を追加します。テーブル
方法 1 の方法に従います。最初の原則は同じです。
ALTER TABLE user ADD PRIMARY KEY(User_id)
原則は、User_id フィールドに PRIMARY KEY を追加することです。
方法 1 の 2 番目の原則と同じです
ALTER TABLE users MODIFY User_id INT PRIMARY KEY;
2. FK (外部キー制約)
1. 外部キーとは何ですか?
外部キーは外部キーワードとも呼ばれ、直接接続を表します。 2つのテーブルの間。あるテーブルの外部キーは、別のテーブルの主キーである必要があります。別のリレーションシップの外部キーを主キーとして持つテーブルはマスター テーブルと呼ばれ、外部キーを持つテーブルはマスター テーブルのスレーブ テーブルと呼ばれます。 。
たとえば、注文テーブルには、製品 ID とユーザー ID という 2 つの外部キーが含まれています。プロダクト ID は製品情報テーブルの主キーであり、ユーザー ID はユーザー テーブルの主キーです。
注: テーブル内に外部キーが複数存在することも、外部キーが存在しないこともあります。
2. 外部キーの設定方法
方法 1: テーブル作成時に外部キー制約を設定する
主キーの前の設定に基づいた例を見てみましょう。先ほど user テーブルを作成したので、今度はorders テーブルを作成します。
CREATE TABLE dingdan( DDid INT PRIMARY KEY NOT NULL, User_id INT NOT null, DDname VARCHAR(20) NOT NULL, -- 设置约束关系,dingdan表中的User_id 与 user表中的User_id表示的是同一个数据 constraint fk FOREIGN KEY(User_id) REFERENCES user(User_id) )
方法 2: テーブルの作成時に主キーは設定されず、後でテーブルに主キーが設定されます。
alter table student add constraint stfk foreign key(stid) references teacher(tid)
注: 主キーと外部キーの関係が確立された後、メインテーブルのデータは自由に削除できません。注文データにユーザー情報が含まれている場合、ユーザー情報の削除時にエラーが発生するため、ユーザー情報を保持しておく必要があります。
3. unique (一意制約)
1. 一意制約とは何ですか?
一意制約がフィールドに設定されている場合、そのフィールドは書き込まれないか、または書き込まれた場合でもそのフィールドを繰り返すことができません。
2. 一意制約の設定方法
さらにユーザー テーブルを作成します。今回はテーブルに電子メール フィールドがあります。電子メールの設定を繰り返すことはできません
CREATE TABLE User( User_id int NOT NULL, User_name VARCHAR(20), User_pwd VARCHAR(18), User_Email VARCHAR(40) UNIQUE )
4. null ではない (空ではない)
は、このフィールドを空にすることができないことを意味します
上記の一意の制約に従って記述します。ここでは、それを記述します。
CREATE TABLE User( User_id int NOT NULL, User_name VARCHAR(20), User_pwd VARCHAR(18), User_Email VARCHAR(40) UNIQUE not null )
5.default (デフォルト値)
は、このフィールドを書き込まないと、次のメッセージが表示されることを意味します。デフォルトで値が設定され、上記の User テーブルへの書き込みを続けます。ここに性別フィールドを追加します。性別を書かない場合、デフォルトは男性
CREATE TABLE User( User_id int NOT NULL, User_name VARCHAR(20), User_pwd VARCHAR(18), User_gender enum('男','女') default '男' )
6です。auto_increment (self-increment)
自動インクリメントとは、自動増分を意味します。つまり、このフィールドにデータを入力しない場合、システムは前のデータに基づいて 1
を自動的に追加します。 ID で使用される数値
は、ユーザー テーブル内の ID を自動インクリメントするように設定します
CREATE TABLE User( User_id int auto_increment, User_name VARCHAR(20), User_pwd VARCHAR(18), User_gender enum('男','女') default '男' )
注: いいえ。データの一部が入力されていない場合、値は次のように指定されます。デフォルト。したがって、ID が主キーであっても、データを入力する必要はありません
以上がMySQLデータベースのテーブルに制約を設定する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

mysqloffersvariousstorageEngines、それぞれのfordifferentusecases:1)Innodbisidealforapplicationsingingidcomplianceanceandhighconcurrency、support transactions andforeignkeys.2)myisamisbestforread-havyworkloads、transactionsupptort.3)

MySQLの一般的なセキュリティの脆弱性には、SQLインジェクション、弱いパスワード、不適切な許可構成、および非合事ソフトウェアが含まれます。 1。SQL注射は、前処理ステートメントを使用することで防ぐことができます。 2。強力なパスワード戦略を強制的に使用することにより、弱いパスワードを回避できます。 3.不適切な許可構成は、ユーザー許可の定期的なレビューと調整を通じて解決できます。 4.未使用のソフトウェアは、MySQLバージョンを定期的にチェックして更新することでパッチを適用できます。

MySQLの遅いクエリを識別することは、遅いクエリログを有効にし、しきい値を設定することで実現できます。 1.スロークエリログを有効にし、しきい値を設定します。 2.スロークエリログファイルを表示および分析し、詳細な分析のためにMySQLDumpSlowやPT-Query-Digestなどのツールを使用します。 3.インデックスの最適化、クエリの書き換え、およびselect*の使用を回避することで、遅いクエリの最適化を実現できます。

MySQLサーバーの健康とパフォーマンスを監視するには、システムの健康、パフォーマンスメトリック、クエリの実行に注意する必要があります。 1)システムの健康を監視する:Top、HTOP、またはShowGlobalStatusコマンドを使用して、CPU、メモリ、ディスクI/O、ネットワークアクティビティを表示します。 2)パフォーマンスインジケーターの追跡:クエリ番号あたりのクエリ番号、平均クエリ時間、キャッシュヒット率などのキーインジケーターを監視します。 3)クエリ実行の最適化を確保します:スロークエリログを有効にし、実行時間が設定されたしきい値を超えるクエリを記録し、最適化します。

MySQLとMariaDBの主な違いは、パフォーマンス、機能、ライセンスです。1。MySQLはOracleによって開発され、Mariadbはフォークです。 2. Mariadbは、高負荷環境でパフォーマンスを向上させる可能性があります。 3.MariaDBは、より多くのストレージエンジンと機能を提供します。 4.MySQLは二重ライセンスを採用し、MariaDBは完全にオープンソースです。既存のインフラストラクチャ、パフォーマンス要件、機能要件、およびライセンスコストを選択する際に考慮する必要があります。

MySQLはGPLライセンスを使用します。 1)GPLライセンスにより、MySQLの無料使用、変更、分布が可能になりますが、変更された分布はGPLに準拠する必要があります。 2)商業ライセンスは、公的な変更を回避でき、機密性を必要とする商用アプリケーションに適しています。

Myisamの代わりにInnoDBを選択する場合の状況には、次のものが含まれます。1)トランザクションサポート、2)高い並行性環境、3)高いデータの一貫性。逆に、Myisamを選択する際の状況には、1)主に操作を読む、2)トランザクションサポートは必要ありません。 INNODBは、eコマースプラットフォームなどの高いデータの一貫性とトランザクション処理を必要とするアプリケーションに適していますが、Myisamはブログシステムなどの読み取り集約型およびトランザクションのないアプリケーションに適しています。

MySQLでは、外部キーの機能は、テーブル間の関係を確立し、データの一貫性と整合性を確保することです。外部キーは、参照整合性チェックとカスケード操作を通じてデータの有効性を維持します。パフォーマンスの最適化に注意し、それらを使用するときに一般的なエラーを避けてください。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック









