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 ディレクティブの例の分析

推薦する

Nginx が Apache より優れている理由

Nginx は、わずか数年で Web サーバー市場の大部分を占めるようになりました。周知のとおり、N...

MySQL で珍しい文字を挿入できないときの対処方法 (文字列値が正しくない)

最近、ビジネス側から、一部のユーザー情報の挿入に失敗し、エラー メッセージが「不正な文字列値:&qu...

動的なテーブル効果を実現するJavaScript

この記事では、動的なテーブル効果を実現するためのJavaScriptの具体的なコードを参考までに紹介...

CSS は Apple のスムーズなスイッチ ボタン効果を模倣します

目次1. コード分析2. ソースコードソースコード1. コード分析1.1 HTMLコード分析 <...

Tomcat を使用して Centos 環境に SpringBoot WAR パッケージをデプロイする

戦争パッケージを準備する1. 既存のSpringBootプロジェクトを準備し、pomに依存関係を追加...

mysql-8.0.16 winx64 最新インストール チュートリアル (画像とテキスト付き)

最近、データベースについて学び始めました。最初にやったことは、データベースとは何か、データベースとデ...

ReactRouterの実装

ReactRouterの実装ReactRouterはReactのコアコンポーネントです。主にReac...

MySQLの基本操作を詳しく解説(第2部)

序文この記事には1. データベースのいくつかの主要な制約2. テーブル間の関係制約:主キー制約: 機...

Mysql GTID Mha 設定方法

Gtid + Mha + Binlog サーバー構成: 1: テスト環境OS: CentOS 6.5...

Jenkins+tomcat の自動ホットデプロイメント/再起動と発生した問題の解決策 (推奨)

1. 背景同社のプロジェクトは、これまでは手動で Maven でパッケージ化し、サーバーにアップロ...

CentOS での MySQL ワークベンチのインストールと設定のチュートリアル

この記事では、MySQL Workbenchのインストールと設定のチュートリアルを参考までに紹介しま...

MySQL のファントムリード問題を解決する方法

目次序文1. ファントムリーディングとは何ですか? 2. ファントムリーディングの問題点は何ですか?...

小さなアイコンのフロントエンド処理ソリューションのグラフィカルな説明

序文この記事を始める前に、複数選択の質問をしてみましょう。フロントエンド開発でビルド ツールを使用す...

Linux yum パッケージ管理方法

導入yum (Yellow dog Updater, Modified) は、Fedora、RedH...

MySqlエスケープの詳細な使用例

MySQL エスケープエスケープとは、エスケープ文字の本来の意味を意味します。エスケープ文字の目的は...