首页 > 后端开发 > php教程 > 请教一个关于php+mysql的问题

请教一个关于php+mysql的问题

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-23 13:50:36
原创
936 人浏览过

要在一个表中查询数据,条件是uid in (1,2,3)。那么满足uid=1或者2或者3的都查询到。
如何做到每满足一个条件只取一条?
例如uid为1,2,3分别都几条,通过sql查询,只查询uid为1的第一条,uid为2的第一条,uid为3的第一条。


回复讨论(解决方案)

首先你的数据当中必须有一个id,一个uid

查询uid为1,2,3分别都几条:(假定表名为'user',表中只有两个字段,分别为id和uid)

select id,count(uid) from user group by uid having uid=1 or uid=2 or uid =3;
登录后复制


查询uid为1的第一条:

select * from user where uid=1 limit 1;
登录后复制

你可以 对查询出来的结果集 在分组 取一条

select * from tbl_name a  where (select count(*) from tbl_name where uid=a.uid and id<a.id) = 1 and uid in (1,2,3)
登录后复制

每个条件只取一条:
 select * from tt where uid in(1,2,3) group by uid ;

select  a.*  from  table a where  1> (select count(1) from table b where a.id = b.id and a.id > b.id ) and a.uid in (1,2,3)

select top 1 * from table group by  id 

group by 可以实现

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
怎么用php+mysql做动态数据表格 , 急!!!
来自于 1970-01-01 08:00:00
0
0
0
php - mysql监控问题
来自于 1970-01-01 08:00:00
0
0
0
php工具箱怎样升级mysql
来自于 1970-01-01 08:00:00
0
0
0
php工具箱能换mysql版本吗?
来自于 1970-01-01 08:00:00
0
0
0
php工具箱 mysql 启动不起来
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板