最新のレコードを保持しながら MySQL の重複レコードを削除する方法
一意の識別子と重複する電子メール アドレスを含むテーブルを扱う場合、次のようになります。多くの場合、最新のレコードを保持しながらこれらの重複を削除する必要があります。 MySQL は、この目的を達成するためにいくつかの方法を提供します。
1 つのアプローチには、繰り返される電子メール アドレスを特定し、これらの電子メールごとに最大 ID で表される最新のレコードを見つけることが含まれます。これは、GROUP BY、HAVING、MAX() 関数を組み合わせて使用できます。
最新のレコードが特定されたら、次のステップは、そのレコードよりも低い ID を持つ重複レコードをすべて削除することです。それぞれの最大ID。これは、INNER JOIN を使用して電子メール アドレスと ID 値を比較する DELETE ステートメントで実行できます。
データベース テーブルの例
このプロセスを説明するには、 「test」という名前の次のテーブル:
ID EMAIL ---------------------- -------------------- 1 aaa 2 bbb 3 ccc 4 bbb 5 ddd 6 eee 7 aaa 8 aaa 9 eee
重複の識別電子メール
select email from test group by email having count(*) > 1;
このクエリは、「aaa」、「bbb」、および「eee」が繰り返される電子メールであることを示す次の結果を返します。
EMAIL -------------------- aaa bbb eee
最新のレコードの検索
select max(id) as lastId, email from test where email in ( select email from test group by email having count(*) > 1 ) group by email;
このクエリは次の内容を取得します各重複の最大 ID と対応する電子メール アドレス:
LASTID EMAIL ---------------------- -------------------- 8 aaa 4 bbb 9 eee
重複レコードの削除
delete test from test inner join ( select max(id) as lastId, email from test where email in ( select email from test group by email having count(*) > 1 ) group by email ) duplic on duplic.email = test.email where test.id <p>このクエリを実行すると、「test」テーブルには次の内容が含まれます。各電子メール アドレスの最新のレコードのみが表示され、次の結果が得られます。データ:</p><pre class="brush:php;toolbar:false"> +----+-------+ | id | email | +----+-------+ | 3 | ccc | | 4 | bbb | | 5 | ddd | | 8 | aaa | | 9 | eee | +----+-------+
最適化された削除クエリ
より最適化された代替の削除クエリを以下に示します:
delete from test where id not in ( select max(id) from test group by email)
以上がMySQL で最新のレコードを保持したまま重複レコードを削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

mysqlviewshavelimitations:1)supportallsqloperations、制限、dataManipulationswithjoinsorubqueries.2)それらは、特にパフォーマンス、特にパルフェクソルラージャターセット

reperusermanmanagementInmysqliscialforenhancingsecurationsinginuring databaseaperation.1)usecreateusertoaddusers、指定connectionsourcewith@'localhost'or@'% '。

mysqldoes notimposeahardlimitontriggers、しかしpracticalfactorsdeTerminetheireffectiveuse:1)serverconufigurationStriggermanagement; 2)complentiggersincreaseSystemload;

はい、それはssafetostoreblobdatainmysql、butonsiderheSeCactors:1)Storagespace:blobscanconsumesificantspace.2)パフォーマンス:パフォーマンス:大規模なドゥエットブロブスメイズ階下3)backupandrecized recized recized recize

PHP Webインターフェイスを介してMySQLユーザーを追加すると、MySQLI拡張機能を使用できます。手順は次のとおりです。1。MySQLデータベースに接続し、MySQLI拡張機能を使用します。 2。ユーザーを作成し、CreateUserステートメントを使用し、パスワード()関数を使用してパスワードを暗号化します。 3. SQLインジェクションを防ぎ、MySQLI_REAL_ESCAPE_STRING()関数を使用してユーザー入力を処理します。 4.新しいユーザーに権限を割り当て、助成金ステートメントを使用します。

mysql'sblobissuitable forstoringbinarydatawithinarationaldatabase、whileenosqloptionslikemongodb、redis、andcassandraofferferulesions forunstructureddata.blobissimplerbutcanslowdowdowd withwithdata

toaddauserinmysql、使用:createuser'username '@' host'identifidedby'password '; here'showtodoitsely:1)chosehostcarefilytoconを選択しますTrolaccess.2)setResourcelimitslikemax_queries_per_hour.3)usestrong、uniquasswords.4)endforcessl/tlsconnectionswith

toavoidcommonMonmistakeswithStringDatatypesinmysql、undultingStringTypenuste、choosetherightType、andManageEncodingandCollationsEttingtingive.1)Usecharforfixed-LengthStrings、Varcharforaible Length、AndText/Blobforlardata.2)setCurrectCherts


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

Dreamweaver Mac版
ビジュアル Web 開発ツール

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

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

WebStorm Mac版
便利なJavaScript開発ツール

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