ホームページ データベース mysql チュートリアル INNER JOIN を使用して複数の SQL Server テーブルからレコードを削除する方法

INNER JOIN を使用して複数の SQL Server テーブルからレコードを削除する方法

Jan 07, 2025 am 07:10 AM

How to Delete Records from Multiple SQL Server Tables Using INNER JOIN?

SQL Server で INNER JOIN を使用して複数のテーブルからレコードを削除する

MySQL とは異なり、SQL Server はレコードの削除に使用される構文を直接サポートしていません。 INNER JOIN を使用して複数のテーブルから。ただし、「削除された」疑似テーブルを利用することで回避策を実現で​​きます。

ステップ 1: 削除された ID を保存するための一時テーブルを初期化する

begin transaction;

declare @deletedIds table ( id int );

ステップ 2: 最初のテーブルから削除し、出力を削除するID

delete from t1
output deleted.id into @deletedIds
from table1 as t1
inner join table2 as t2
  on t2.id = t1.id
inner join table3 as t3
  on t3.id = t2.id;

ステップ 3: 一時テーブルを使用して 2 番目のテーブルから削除

delete from t2
from table2 as t2
inner join @deletedIds as d
  on d.id = t2.id;

ステップ 4: 追加のテーブルから削除(オプション)

delete from t3
from table3 as t3 ...

ステップ 5: トランザクションをコミットする

commit transaction;

注: 最初から削除された ID を出力します削除すると、次回以降も参加を続けることができますdeletions.

代替アプローチ: トリガー

別の方法として、最初のテーブルにトリガーを作成して、他のテーブルの関連レコードの削除を処理することもできます。このアプローチにより、暗黙的なトランザクション内のデータの整合性が保証されます。ただし、追加のトリガーのメンテナンスが必要であり、複雑な結合条件はすぐにはサポートされません。

以上がINNER JOIN を使用して複数の SQL Server テーブルからレコードを削除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットAIツール

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

MySQLサーバーへの安全なリモート接続を確立します MySQLサーバーへの安全なリモート接続を確立します Jul 04, 2025 am 01:44 AM

tosecurelyconnecttoaremotemysqlserver、usesshtunneling、configuremysqlforremoteacess、setfirewallrules、andconsidersslencryption .first、Encistishansshtunnelwithssh-l3307:localhost:3306user@remote-server-nandconnectviamysql-h127.0.0.1-p3307.second、editmys

MySQLデータの整合性における外国の鍵の役割を理解する MySQLデータの整合性における外国の鍵の役割を理解する Jul 03, 2025 am 02:34 AM

foreignkeysinmysqlensuredategritybyenforcingrelationshipsbetweentables.thepreventorphanedrecords、restrictinvaliddataentry、andcancascadechangesautomativitive.mustusetheetheintein nodbstorageine、およびforeidmatekolumnsmatchedtatepeofeofeofefe

mysqlでmysqldumpを使用して論理バックアップを実行します mysqlでmysqldumpを使用して論理バックアップを実行します Jul 06, 2025 am 02:55 AM

MySQLDUMPは、MySQLデータベースの論理バックアップを実行するための一般的なツールです。データベースを再構築するための作成および挿入ステートメントを含むSQLファイルを生成します。 1.元のファイルをバックアップするのではなく、データベースの構造とコンテンツをポータブルSQLコマンドに変換します。 2。小さなデータベースや選択的回復に適しており、TBレベルのデータの迅速な回復には適していません。 3.一般的なオプションには、-single-Transaction、 - database、 - all-database、 - routinesなどが含まれます。 4. MySQLコマンドを使用して回復中にインポートし、外部キーチェックをオフにして速度を向上させることができます。 5.バックアップを定期的にテストし、圧縮と自動調整を使用することをお勧めします。

MySQLスロークエリログを分析して、パフォーマンスボトルネックを見つける MySQLスロークエリログを分析して、パフォーマンスボトルネックを見つける Jul 04, 2025 am 02:46 AM

MySQLスロークエリログをオンにし、位置づけ可能なパフォーマンスの問題を分析します。 1.構成ファイルを編集するか、動的にSLOW_QUERY_LOGおよびLONG_QUERY_TIMEを設定します。 2。ログには、query_time、lock_time、rows_examinedなどの重要なフィールドが含まれており、効率のボトルネックの判断を支援します。 3. mysqldumpslowまたはpt-query-digestツールを使用して、ログを効率的に分析します。 4.最適化の提案には、インデックスの追加、Select*の回避、複雑なクエリの分割などが含まれます。たとえば、user_idにインデックスを追加すると、スキャンされた行の数を大幅に削減し、クエリ効率を改善できます。

mysql列とクエリのnull値を処理します mysql列とクエリのnull値を処理します Jul 05, 2025 am 02:46 AM

mysqlでnull値を処理する場合、次の手に注意してください。1。テーブルを設計する場合、キーフィールドはnotnullに設定され、オプションのフィールドはnullを許可されます。 2。ISNULLまたはISNOTNULLは、=または!=;で使用する必要があります。 3. IFNULLまたはCoalesce関数を使用して、表示のデフォルト値を置き換えることができます。 4.挿入または更新時にnull値を直接使用する場合は注意し、データソースとORMフレームワークの処理方法に注意を払ってください。 nullは未知の値を表し、それ自体を含む値と等しくありません。したがって、テーブルをクエリ、カウント、および接続するときは、データや論理エラーの欠落を避けるときは注意してください。関数と制約の合理的な使用は、ヌルによる干渉を効果的に減らすことができます。

mysqlサーバーのルートパスワードをリセットします mysqlサーバーのルートパスワードをリセットします Jul 03, 2025 am 02:32 AM

MySQLのルートパスワードをリセットするには、次の手順に従ってください。1。mysqlサーバーを停止し、sudosystemctlstopmysqlまたはsudosystemctlstopmysqldを使用してください。 2。-skip-grant-tablesモードでmysqlを起動し、sudomysqld-skip-grant-tablesを実行します&; 3. mysqlにログインし、対応するsqlコマンドを実行して、flushprivilegesなどのバージョンに従ってパスワードを変更します。

MySQLのデータベースとテーブルサイズの計算 MySQLのデータベースとテーブルサイズの計算 Jul 06, 2025 am 02:41 AM

MySQLデータベースとテーブルのサイズを表示するには、Information_schemaを直接照会するか、コマンドラインツールを使用できます。 1.データベースサイズ全体を確認します。SQLステートメントSelectTable_schemaas'Database '、sum(data_length index_length)/1024/1024as'size(mb)' frominformation_schema.tablesgroupbytable_schema;すべてのデータベースの合計サイズを取得するか、特定のデータベースを制限する条件を追加することができます。 2。単一のテーブルサイズを確認します:SelectTaを使用します

MySQLの文字セットと照合の問題を処理します MySQLの文字セットと照合の問題を処理します Jul 08, 2025 am 02:51 AM

クロスプラットフォームの移行またはマルチパーソン開発の場合、文字セットとソートルールの問題は一般的になり、その結果、文字化けされたコードまたは一貫性のないクエリが発生します。 3つのコアソリューションがあります。最初に、データベース、テーブル、およびフィールドの文字セットをUTF8MB4にチェックして統合し、showCreateDatabase/テーブルを介して表示し、ALTERステートメントで変更します。次に、クライアントが接続するときにUTF8MB4文字セットを指定し、接続パラメーターに設定するか、SetNamesを実行します。第三に、ソートルールを合理的に選択し、UTF8MB4_UNICODE_CIを使用して比較と並べ替えの正確性を確保し、ライブラリとテーブルを構築するときに変更を介して指定または変更することをお勧めします。

See all articles