MySQL query duplicate data (delete duplicate data and keep the one with the smallest id as the only data)

MySQL query duplicate data (delete duplicate data and keep the one with the smallest id as the only data)

Development Background:

Recently, I am working on a function to import batch data into a MySQL database. From the batch import, we can know that such data will not be judged as duplicate before being inserted into the database. Therefore, only after all the data is imported, a statement is executed to delete it to ensure the uniqueness of the data.

Let’s take a look at the detailed introduction.

Actual combat:

The table structure is shown in the following figure:

Indicates: brand

operate:

Use SQL statements to query what duplicate data there are:

SELECT * from brand WHERE brandName IN (
select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1 #The condition is that the number of duplicate data is greater than 1)

Use SQL to delete redundant duplicate data and keep the unique data with the smallest ID:

Note:

Wrong SQL: DELETE FROM brand WHERE brandName IN (select brandName from brand GROUP BY brandName HAVING COUNT(brandName)>1)
AND Id NOT IN (select MIN(Id) from brand GROUP BY brandName HAVING COUNT(brandName)>1)

Tip: You can't specify target table 'brand' for update in FROM clause

The reason is: the data directly found cannot be used as the condition for deleting data. We should first create a temporary table for the found data, and then use the temporary table as the condition for deletion.

Correct SQL writing:
 DELETE FROM brand WHERE brandName IN (SELECT brandName FROM (SELECT brandName FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) e)
 AND Id NOT IN (SELECT Id FROM (SELECT MIN(Id) AS Id FROM brand GROUP BY brandName HAVING COUNT(brandName)>1) t)

#Querying for duplicate data only displays the first few items, so there is no need to query whether it is the minimum value

The results are as follows:


Summarize:

Many things need to be explored step by step by yourself. Of course, the suggestions on the Internet are also very valuable references and resources. No matter what development we do, we need to understand its working principles in order to better master it.

Well, the above is the full content of this article. I hope that the content of this article will have certain reference learning value for your study or work. If you have any questions, you can leave a message to communicate. Thank you for your support of 123WORDPRESS.COM.

You may also be interested in:
  • Find duplicate records in mysql table
  • MySQL SQL statement to find duplicate data based on one or more fields
  • Detailed explanation of how to find and delete duplicate data in MySQL and keep only one example
  • How to query duplicate data in mysql table
  • Summary of methods for deleting duplicate data in MySQL database
  • Very comprehensive MySQL code for handling duplicate data
  • Summary of methods for deleting duplicate records in MySQL database [Recommended]
  • Share the method of ignoring duplicate data when inserting data in MYSQL
  • MySQL uses UNIQUE to implement non-duplicate data insertion
  • A practical record of checking and processing duplicate MySQL records on site

<<:  Implementation of React star rating component

>>:  Linux sudo vulnerability could lead to unauthorized privileged access

Recommend

Using react-virtualized to implement a long list of images with dynamic height

Table of contents Problems encountered during dev...

How to add double quotes in HTML title

<a href="https://www.jb51.net/" titl...

Common tags in XHTML

What are XHTML tags? XHTML tag elements are the b...

Docker file storage path, modify port mapping operation mode

How to get the container startup command The cont...

Vue implements Tab tab switching

This article example shares the specific code of ...

Several methods to clear floating (recommended)

1. Add an empty element of the same type, and the...

How to use cutecom for serial communication in Ubuntu virtual machine

Using cutecom for serial communication in Ubuntu ...

How to use mixins in Vue

Table of contents Preface How to use Summarize Pr...

Vue+flask realizes video synthesis function (drag and drop upload)

Table of contents We have written about drag and ...

Summary of Operator Operations That Are Very Error-Prone in JavaScript

Table of contents Arithmetic operators Abnormal s...

A brief discussion on the application of Html web page table structured markup

Before talking about the structural markup of web...

calc() to achieve full screen background fixed width content

Over the past few years, there has been a trend i...

Summary of Common Commands for Getting Started with MySQL Database Basics

This article uses examples to describe the common...

Detailed explanation of the loop form item example in Vue

Sometimes we may encounter such a requirement, th...