Mysql のいくつかの複雑な SQL ステートメント (重複行のクエリと削除)

Mysql のいくつかの複雑な SQL ステートメント (重複行のクエリと削除)

1. 重複行を見つける

blog_user_relation a から * を選択 WHERE (a.account_instance_id,a.follow_account_instance_id) 
IN (SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING
 カウント(*) > 1)

2. 重複行を削除する(1行を残す)

PS: MySQL の削除のため、削除されたテーブルの where 条件に in が含まれており、このテーブルも in に存在する場合は、削除できません。

/*一時テーブルを作成する*/
blog_user_relation_temp というテーブルを作成します
(
 SELECT * FROM blog_user_relation a WHERE 
 (a.アカウントインスタンスID、a.フォローアカウントインスタンスID) 
 IN ( SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT(*) > 1)
 そして 
 リレーションID 
 NOT IN (SELECT MIN(relation_id) FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT(*)>1));

/*データを削除*/
`blog_user_relation` から relationship_id を削除します (relation_id を blog_user_relation_temp から選択します)。

/*一時テーブルを削除*/
blog_user_relation_temp テーブルを削除します。

以下もご興味があるかもしれません:
  • SQLバッチ置換ステートメントを使用して、フィールドの内容を変更、追加、削除します。
  • 重複レコードを削除し、1つだけ残すSQL文
  • 知っておくべきSQL文(IV)データの削除と更新
  • 知っておくべきSQL文(パート2)テーブルの作成、テーブル構造の変更、テーブルの削除
  • SQL ステートメントを使用して制約を作成および削除するためのサンプル コード
  • OracleはSQL文を使用してフィールドを追加します(SQLフィールド削除文)
  • MySQL で指定されたプレフィックス テーブルを一括削除する SQL ステートメント
  • SQL ステートメントを使用して外部キーと主キーを削除および追加する方法
  • MySQL の Delete および Truncate ステートメントの比較
  • 一般的なSQL削除ステートメントの原則の違いを理解するだけです

<<:  js でパズルゲームを実装する

>>:  nginx での listen ディレクティブの例の分析

推薦する

Linux システム MySQL8.0.19 クイックインストールと構成チュートリアル図

目次1. 環境の紹介2. MySQL-8.0.19をインストールする3. MySQLを設定する1. ...

Linux curl フォームのログインまたは送信と Cookie の使用に関する詳細な説明

序文この記事では主に、curl を介してフォーム送信ログインを実装する方法について説明します。単一の...

MySQL 5.7 の sql_mode のデフォルト値によって生じる落とし穴と解決策

通常のプロジェクト開発中に、MySQL バージョンが 5.6 から 5.7 にアップグレードされた場...

JS クロスドメイン ソリューション React 構成 リバース プロキシ

クロスドメインソリューションjsonp (get をシミュレート) CORS (クロスオリジンリソー...

Linux 上の Tomcat で MySQL にデータを挿入するときに中国語の文字化けが発生する問題を解決する

1. 問題Windows 上の Eclipse を使用して開発されたプロジェクトは Windows ...

MySQL 完全折りたたみクエリ正規マッチングの詳細な説明

概要前の章では、クエリのフィルター条件について学習しました。MySQL では、like % ワイルド...

Vue3 ミックスインの使い方

目次1. mixin の使い方は? 2. ミックスイン使用時の注意2.1. ミックスイン オブジェク...

構造とプレゼンテーションの分離を理解するためのWeb標準の学習

Web 標準について議論するときに必ず話題になるのは、構造とプレゼンテーションを分離することの重要性...

DOCTYPEタイプの詳細な紹介

<br />通常、HTML では次の方法で DOCTYPE を宣言します。 <!D...

docker-maven-plugin の詳細な使用方法

目次Docker-Maven-プラグインMavenプラグインの自動デプロイメント手順1. ホストマシ...

IE、Firefox、Chromeブラウザではスペースの表示が異なります

&nbsp;&nbsp;IE、Firefox、Chrome ブラウザでの表示効果は、...

CSS3のall属性の使い方を理解する

1. 互換性以下のように表示されます。 互換性は問題ありません。IE を除き、他のブラウザは基本的に...

Alibaba Cloud Server Ubuntu 上の Workbench が MySQL に接続できない問題の解決策 (テスト済み)

過去 2 日間、ワークベンチが Alibaba Cloud Server に接続できない問題を解決す...

Linux コマンド クエリ アプレットでの WePY クラウド開発の実践

みなさんこんにちは。今日は Linux コマンド クエリ アプレットでの WePY クラウド開発の実...

MySQL で 1 つのテーブルのフィールドを使用して別のテーブルのフィールドを更新する方法

1. 1列を変更する 学生の更新、都市c s.city_name = c.name を設定します こ...