ホームページ データベース mysql チュートリアル 子行を追加または更新できません: 外部キー制約が失敗します - MySQL エラーを解決する方法: 子行に外部キー制約があります

子行を追加または更新できません: 外部キー制約が失敗します - MySQL エラーを解決する方法: 子行に外部キー制約があります

Oct 05, 2023 am 08:22 AM
解決 外部キー制約 mysqlエラー

Cannot add or update a child row: a foreign key constraint fails - 如何解决MySQL报错:子行有外键约束

MySQL エラーを解決する方法: サブ行には外部キー制約があり、特定のコード例が必要です

MySQL データベースを使用すると、「追加できません」というエラーが発生することがあります。または子行を更新します: 外部キー制約が失敗します」というエラーが発生します。このエラーは通常、データの挿入または更新時の外部キー制約の問題を示します。この記事では、この問題を解決する方法を説明し、具体的なコード例を示します。

まず、外部キー制約について理解しましょう。データベースでは、外部キーはテーブル間の接続を確立するために使用される関係です。これは別のテーブルの主キーを指し、データの一貫性と整合性を維持するために使用されます。外部キー制約はデータの挿入または更新を制限します。指定された条件が満たされる必要があり、満たさない場合はエラーがスローされます。

「子行を追加または更新できません: 外部キー制約が失敗しました」エラーが発生した場合、通常は次のいずれかの理由が原因です。外部キー制約がありますが、挿入または更新されたデータが制約を満たしていません。

    外部キー制約がありますが、対応する主キーがメインテーブルに存在しません。
  1. 次に、いくつかの一般的な解決策を示します。

データが外部キー制約を満たしているかどうかを確認します。データを挿入または更新する前に、データが外部キーを満たしていることを確認してください。制約条件。たとえば、外部キーが別のテーブルの主キーに関連している場合、外部キー フィールドで挿入または更新されるデータは主テーブルに存在する必要があります。

    対応する主キーがメイン テーブルに存在するかどうかを確認します。対応する主キーがメイン テーブルに存在しない場合、サブテーブルでデータを挿入または更新するときに外部キー制約エラーがトリガーされます。この場合、まず対応する主キー データをメイン テーブルに挿入してから、サブテーブルを挿入または更新する必要があります。
  1. 次は、この問題の解決方法を示す具体的なコード例です。
users テーブル (users) と order テーブル (orders) の 2 つのテーブルがあるとします。ユーザー テーブルの主キーはユーザー ID (user_id) で、順序テーブルの外部キーはユーザー ID であり、ユーザー テーブルを関連付けるために使用されます。

まず、ユーザー テーブルを作成します。

CREATE TABLE users(

user_id INT PRIMARY KEY AUTO_INCREMENT,

username VARCHAR(50) NOT NULL

);

次に、order テーブルを作成します。

CREATE TABLEorders(

order_id INT PRIMARY KEY AUTO_INCREMENT,

user_id INT,

order_date DATE,
FOREIGN KEY (user_id ) REFERENCES users(user_id)
);

ここで、order テーブルにデータを挿入したいのですが、user テーブルにユーザー ID が存在しない場合、外部キー制約エラーが発生します。トリガーされます。この問題を解決するには、まず対応するユーザー データをユーザー テーブルに挿入し、次に注文データを挿入します。

-- 最初にユーザー データを挿入

INSERT INTO users(username) VALUES ( 'John ');

-- 次に、注文データを挿入します
INSERT INTOorders(user_id, order_date) VALUES (1, '2022-01-01');

上記の手順を実行します。コード例を使用すると、「子行を追加または更新できません: 外部キー制約が失敗します」というエラーを解決できます。

要約すると、このエラーを解決するときは、データが外部キー制約の条件を満たしていること、および対応する主キーがメイン テーブルに存在することを確認する必要があります。データとテーブルの構造を注意深く確認し、正しい順序でデータを挿入または更新することで、この問題を正常に解決できます。

この記事の内容が、「子行を追加または更新できません: 外部キー制約が失敗しました」エラーの解決に役立つことを願っています。同様の問題が発生した場合は、特定の状況に基づいて適切な解決策を講じ、上記のコード サンプルを参照してください。 MySQL データベースの運用を頑張ってください。

以上が子行を追加または更新できません: 外部キー制約が失敗します - MySQL エラーを解決する方法: 子行に外部キー制約がありますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ブートストラップテーブルがajaxを使用してデータを取得する場合はどうすればよいですか ブートストラップテーブルがajaxを使用してデータを取得する場合はどうすればよいですか Apr 07, 2025 am 11:54 AM

AJAXを使用してサーバーからデータを取得する場合の文字化けコードのソリューション:1。サーバー側コード(UTF-8など)の正しい文字エンコードを設定します。 2. AJAXリクエストでリクエストヘッダーを設定し、受け入れられている文字エンコード(Accept-Charset)を指定します。 3.ブートストラップテーブルの「UNESCAPE」コンバーターを使用して、脱出したHTMLエンティティを元の文字にデコードします。

ブートストラップリストでデフォルトスタイルを削除する方法は? ブートストラップリストでデフォルトスタイルを削除する方法は? Apr 07, 2025 am 10:18 AM

ブートストラップリストのデフォルトスタイルは、CSSオーバーライドで削除できます。より具体的なCSSルールとセレクターを使用し、「近接原理」と「重量原理」に従って、ブートストラップのデフォルトスタイルをオーバーライドします。スタイルの競合を避けるために、よりターゲットを絞ったセレクターを使用できます。オーバーライドが失敗した場合は、カスタムCSSの重量を調整します。同時に、パフォーマンスの最適化に注意を払い、重要な!の過剰使用を避け、簡潔で効率的なCSSコードを書いてください。

データベースに対するNAVICATのソリューションを接続できません データベースに対するNAVICATのソリューションを接続できません Apr 08, 2025 pm 11:12 PM

次の手順を使用して、NAVICATがデータベースに接続できない問題を解決できます。サーバー接続を確認し、サーバーが実行されていることを確認、アドレス指定、ポートを正しく確認し、ファイアウォールにより接続を許可します。ログイン情報を確認し、ユーザー名、パスワード、許可が正しいことを確認します。ネットワーク接続を確認し、ルーターやファイアウォールの障害などのネットワークの問題をトラブルシューティングします。一部のサーバーでサポートされていない場合があるSSL接続を無効にします。データベースバージョンをチェックして、NAVICATバージョンがターゲットデータベースと互換性があることを確認してください。接続タイムアウトを調整し、リモートまたは遅い接続の場合は、接続タイムアウトタイムアウトを増やします。その他の回避策は、上記の手順が機能していない場合は、別の接続ドライバーを使用してソフトウェアを再起動したり、データベース管理者または公式NAVICATサポートに相談したりすることができます。

特定のシステムバージョンでMySQLが報告したエラーのソリューション 特定のシステムバージョンでMySQLが報告したエラーのソリューション Apr 08, 2025 am 11:54 AM

MySQLのインストールエラーのソリューションは次のとおりです。1。システム環境を慎重に確認して、MySQL依存関係ライブラリの要件が満たされていることを確認します。異なるオペレーティングシステムとバージョンの要件は異なります。 2.エラーメッセージを慎重に読み取り、依存関係のインストールやSUDOコマンドの使用など、プロンプト(ライブラリファイルの欠落やアクセス許可など)に従って対応する測定値を取得します。 3.必要に応じて、ソースコードをインストールし、コンパイルログを慎重に確認してみてください。これには、一定量のLinuxの知識と経験が必要です。最終的に問題を解決する鍵は、システム環境とエラー情報を慎重に確認し、公式の文書を参照することです。

MySQLを解く方法は、ローカルホストに接続できません MySQLを解く方法は、ローカルホストに接続できません Apr 08, 2025 pm 02:24 PM

MySQL接続は、次の理由が原因である可能性があります。MySQLサービスは開始されず、ファイアウォールは接続をインターセプトし、ポート番号が間違っています。ユーザー名またはパスワードが間違っています。My.cnfのリスニングアドレスは不適切に構成されています。トラブルシューティング手順には以下が含まれます。 2.ファイアウォール設定を調整して、MySQLがポート3306をリッスンできるようにします。 3.ポート番号が実際のポート番号と一致していることを確認します。 4.ユーザー名とパスワードが正しいかどうかを確認します。 5. my.cnfのバインドアドレス設定が正しいことを確認してください。

rootとしてmysqlにログインできません rootとしてmysqlにログインできません Apr 08, 2025 pm 04:54 PM

ルートとしてMySQLにログインできない主な理由は、許可の問題、構成ファイルエラー、一貫性のないパスワード、ソケットファイルの問題、またはファイアウォール傍受です。解決策には、構成ファイルのBind-Addressパラメーターが正しく構成されているかどうかを確認します。ルートユーザー許可が変更されているか削除されてリセットされているかを確認します。ケースや特殊文字を含むパスワードが正確であることを確認します。ソケットファイルの許可設定とパスを確認します。ファイアウォールがMySQLサーバーへの接続をブロックすることを確認します。

VUEでデフォルトのエクスポートを使用する方法 VUEでデフォルトのエクスポートを使用する方法 Apr 07, 2025 pm 07:21 PM

VUEのデフォルトのエクスポートが明らかになります:デフォルトのエクスポート、名前を指定せずにモジュール全体を一度にインポートします。コンポーネントはコンパイル時にモジュールに変換され、使用可能なモジュールはビルドツールを介してパッケージ化されます。名前付きのエクスポートと組み合わせて、定数や関数などの他のコンテンツをエクスポートできます。よくある質問には、循環依存関係、パスエラー、およびビルドエラーが含まれ、コードとインポートステートメントを慎重に調べる必要があります。ベストプラクティスには、コードセグメンテーション、読みやすさ、コンポーネントの再利用が含まれます。

PHPとBootstrapテーブルの文字化けコードの問題を解決する方法 PHPとBootstrapテーブルの文字化けコードの問題を解決する方法 Apr 07, 2025 am 11:27 AM

ブートストラップテーブルを使用して中国の文字盤を表示するソリューション:1。PHP文字セットをUTF-8に設定します。 2. PHPスクリプトで文字セットを設定します。 3.データベース文字セットがUTF-8であることを確認してください。 4.ブートストラップテーブルの文字セットを「Zh-Cn」に設定します。 5。Mbstringを使用して、キャストキャラクターセットを拡張します。 6.他のエンコーディングからのトランスコードデータ。 7.ブラウザエンコーディングを確認します。

See all articles