When using MySQL, you sometimes need to query records with unique fields. Although MySQL provides the keyword distinct to filter out redundant duplicate records, only one record is retained, but it is often used to return the number of records that do not repeat, instead of returning all values that do not record the record. The reason is that distinct can only return its target field, but cannot return other fields. This problem has plagued me for a long time. If distinct cannot solve this problem, I only need to use double loop query to solve it, this will undoubtedly directly affect the efficiency of a station with a large data volume. So I spent a lot of time studying this problem, and I couldn't find a solution on the Internet. During this period, I pulled Rong for help, the result is that both of us are depressed .........
Let's take a look at the example below:
Table
ID name
1
2 B
3 C
4 C
5 B
The library structure is like this. This is just a simple example, and the actual situation is much more complicated.
For example, if you want to use a statement to query all data with no duplicate names, you must use distinct to remove redundant duplicate records.
Select distinct name from table
The result is:
Name
A
B
C
It seems that the effect has been achieved, but what I want to get is the ID value? Modify the query statement:
Select distinct name, ID from table
The result is:
ID name
1
2 B
3 C
4 C
5 B
How does distinct not work? It works, but it also applies to two fields, that is, it must have the same ID and name to be excluded .......
Modify the query statement again:
Select ID, distinct name from table
Unfortunately, you cannot get anything except the error message. You must start with distinct. Is it difficult to place distinct in the where condition? Yes. An error is reported as a result .......
Very troublesome? Indeed, this problem cannot be solved with all the effort. No way. Continue to ask.
Hold the company's JavaProgramClerk, he showed me how to use distinct in Oracle and didn't find the solution in MySQL. He suggested me try group by before getting off work.
I tried it for a long time, and I couldn't do it. I finally found a usage in the MySQL manual. I realized what I needed with group_concat (distinct name) and group by name, try it now.
Error ............ Depressed ....... I can't even go through the MySQL manual. I gave me hope first, and then pushed me to disappointment ....
Check again. The group_concat function is supported by 4.1, dizzy. I have 4.0. No way. Upgrade. The upgrade is successful ......
Finally, the customer must be asked to upgrade.
Suddenly, the ghost machine flashed. Since the group_concat function can be used, can other functions be used?
Use the count function to try it out. I am a success ....... It takes so much time to cry ........ It turns out to be so simple ......
Now release the complete statement:
Select *, count (distinct name) from Table group by name
Result:
ID name count (distinct name)
1 A 1
2 B 1
3 C 1
The last item is redundant, so you don't have to worry about it. The goal is achieved .....
Alas, it turned out that MySQL was so stupid that I would just lie to him with just a few clicks. I am so depressed (by the way, there is also the guy Rong). Now I hope you will not be overwhelmed by this problem.
Oh, yes. By the way, group by must be placed before order by and limit. Otherwise, an error will be reported ........! OK
This article from the csdn blog, reproduced please indicate the source: http://blog.csdn.net/guocuifang655/archive/2009/03/16/3993612.aspx