Detailed Introduction to the MySQL Keyword Distinct

Detailed Introduction to the MySQL Keyword Distinct

Introduction to the usage of MySQL keyword Distinct

DDL

Prepare SQL:

create table test(id bigint not null primary key auto_increment,
   name varchar(10) not null,
   phone varchar(10) not null,
   email varchar(30) not null)engine=innodb;

Prepare Data:

 insert into test(name, phone, email)values('alibaba','0517','[email protected]');
  insert into test(name, phone, email)values('alibaba','0517','[email protected]');
  insert into test(name, phone, email)values('baidu','010','[email protected]');
  insert into test(name, phone, email)values('tencent','0755','[email protected]');
  insert into test(name, phone, email)values('vipshop','020','[email protected]');
  insert into test(name, phone, email)values('ctrip','021','[email protected]');
  insert into test(name, phone, email)values('suning','025','[email protected]');

The query data is shown in the following figure:

What is the meaning of the word "money"? title=

In the first case, use the Distinct keyword to query single-column data, as shown in the following figure:

What is the meaning of the word "a"? title=

Result: The name field is deduplicated, which meets expectations. The duplicate field value alibaba is indeed filtered out.

In the second case, use the Distinct keyword (in front) to query multiple columns of data, as shown in the following figure:

What is the meaning of the word "invisible"? title=

Result: The name field is deduplicated, but the result does not meet expectations. The duplicate field value alibaba is not filtered out.

In the second case, use the Distinct keyword (after) to query multiple columns of data, as shown in the following figure:

What is the meaning of the word "invisible"? title=

Result: The name field is deduplicated, but the result does not meet expectations. A SQL exception is thrown with error code 1064.

Solution:

Don't use subqueries, use grouping to solve it:

瑙e喅鏂瑰紡

Summary: If the SQL query can be solved with one statement, try not to increase the complexity of SQL, especially subqueries! ! !

The above is an explanation of the usage of the MySQL keyword Distinct. If you have any questions, please leave a message or discuss on this site. Thank you for reading and I hope it can help everyone. Thank you for your support of this site!

You may also be interested in:
  • How to optimize MySQL index function based on Explain keyword
  • Detailed explanation of mysql execution plan id is empty (UNION keyword)
  • jq.ajax+php+mysql to implement keyword fuzzy query (example explanation)
  • MySql multi-condition query statement with OR keyword
  • Explanation of the execution priority of mySQL keywords

<<:  Summary of practical methods for JS beginners to process arrays

>>:  Sample code for implementing two-way authentication with Nginx+SSL

Recommend

MySQL deadlock routine: inconsistent batch insertion order under unique index

Preface The essence of deadlock is resource compe...

Detailed explanation of the basic usage of VUE watch listener

Table of contents 1. The following code is a simp...

Web page comments cause text overflow in IE

The experimental code is as follows: </head>...

10 key differences between HTML5 and HTML4

HTML5 is the next version of the HTML standard. M...

How to install ElasticSearch on Docker in one article

Table of contents Preface 1. Install Docker 2. In...

Meta declaration annotation steps

Meta declaration annotation steps: 1. Sort out all...

Web page image optimization tools and usage tips sharing

As a basic element of a web page, images are one ...

Detailed explanation of the usage of the ESCAPE keyword in MySQL

MySQL escape Escape means the original semantics ...

Vue implements adding watermark to uploaded pictures

This article shares the specific implementation c...

How to recover data after accidentally deleting ibdata files in mysql5.7.33

Table of contents 1. Scenario description: 2. Cas...

How to deploy nginx with Docker and modify the configuration file

Deploy nginx with docker, it's so simple Just...