Given table
| id | user | 
| 1  | 1    |
| 1  | 2    |
| 1  | 3    |
| 1  | 4 开发者_Python百科   |
| 2  | 5    |
| 2  | 6    |
| 2  | 7    |
| 2  | 8    |
I want to write a query that will return 3 rows for id=1 and 3 rows for id=2 (order does not matter, yet I would assume that it can be enforced).
So the end result should be something like (Note, 3 rows for each id):
| id | user | 
| 1  | 1    |
| 1  | 2    |
| 1  | 3    |
| 2  | 5    |
| 2  | 7    |
| 2  | 8    |
How should I write this SQL? My attempts with HAVING have not brought something useful so far.
Thank you, Maxim.
i hope this link help :
http://blog.aharbick.com/2006/09/mysql-groupwise-limiting.html
more in the answers of this questions :
mysql limit inside group?
MYSQL - Group by limit
There are several questions here on SO which cover this area.
I suspect that what you want is
SELECT DISTINCT *
     FROM my_table;
but that wouldn't be the answer to the question a you have stated it, which appears to want three arbitrarily selected rows if I read it correctly.
You can use:
select  top 3 * from [Table_Name] where id='1' or id='2'
 
         
                                         
                                         
                                         
                                        ![Interactive visualization of a graph in python [closed]](https://www.devze.com/res/2023/04-10/09/92d32fe8c0d22fb96bd6f6e8b7d1f457.gif) 
                                         
                                         
                                         
                                         加载中,请稍侯......
 加载中,请稍侯......
      
精彩评论