Detailed example of removing duplicate data in MySQL

Detailed example of removing duplicate data in MySQL

Detailed example of removing duplicate data in MySQL

There are two meanings of duplicate records: one is a completely duplicate record, that is, all fields are repeated; the other is a record with some fields repeated. The first type of duplication is relatively easy to solve. You only need to use the distinct keyword in the query statement to remove duplicates. Almost all database systems support the distinct operation. The main reason for this duplication is poor table design, which can be avoided by adding a primary key or unique index column to the table.

select distinct * from t;

For the second type of duplicate problem, it is usually required to query any one of the duplicate records. Assume that table t has three fields: id, name, and address. id is the primary key. The repeated fields are name and address. It is required to get a unique result set for these two fields.

-- Oracle, MySQL, using correlated subqueries

select * from t t1

 where t1.id =

 (select min(t2.id)

  from t t2

  where t1.name = t2.name and t1.address = t2.address);

-- Hive only supports subqueries in the FROM clause. Subqueries must have names and columns must be unique.

select t1.*

 from t t1,

   (select name, address, min(id) id from t group by name, address) t2

 where t1.id = t2.id;

 

-- You can also use hive's row_number() analysis function

select t.id, t.name, t.address

 from (select id, name, address,

row_number() over (distribute by name, address sort by id) as rn 

     from t) t 

 where t.rn=1;

Thank you for reading, I hope it can help you, thank you for your support of this site!

You may also be interested in:
  • Summary of methods for finding and deleting duplicate data in MySQL tables
  • MySQL query duplicate data (delete duplicate data and keep the one with the smallest id as the only data)
  • MySQL SQL statement to find duplicate data based on one or more fields
  • MySQL study notes on handling duplicate data

<<:  Sample code for implementing login and registration template in Vue

>>:  Detailed steps for quick installation of openshift

Recommend

MySQL concurrency control principle knowledge points

Mysql is a mainstream open source relational data...

Centos6.9 installation Mysql5.7.18 step record

Installation sequence rpm -ivh mysql-community-co...

jQuery plugin to implement accordion secondary menu

This article uses a jQuery plug-in to create an a...

A brief discussion of 3 new features worth noting in TypeScript 3.7

Table of contents Preface Optional Chaining Nulli...

Are the value ranges of int(3) and int(10) the same in mysql

Table of contents Question: answer: Reality: Know...

Analysis and treatment of scroll bars in both HTML and embedded Flash

We often encounter this situation when doing devel...

Tutorial on how to deploy LNMP and enable HTTPS service

What is LNMP: Linux+Nginx+Mysql+(php-fpm,php-mysq...

Troubleshooting the cause of 502 bad gateway error on nginx server

The server reports an error 502 when synchronizin...

Issues with using Azure Container Registry to store images

Azure Container Registry is a managed, dedicated ...

Docker automated build Automated Build implementation process diagram

Automated build means using Docker Hub to connect...

How to use SVG icons in WeChat applets

SVG has been widely used in recent years due to i...

JavaScript style object and CurrentStyle object case study

1. Style object The style object represents a sin...