sql根据某一个字段重复只取第一条数据

sql根据某一个字段重复只取第一条数据,像我们这里只考虑手机重复,要是手机重复,我们只取第一条记录。不考虑圈红色部分最后一个字段不一样,怎么解决?哪位好心人帮忙下嘿亲,其... sql根据某一个字段重复只取第一条数据,像我们这里 只考虑手机重复,要是手机重复,我们只取第一条记录。不考虑圈红色部分最后一个字段不一样,怎么解决?
哪位好心人帮忙下嘿
亲,其实这里是要针对Excel 表导入进行过滤的(Excel表导入到SQL数据库的表已经写在asp.net方法里辣),Excel表导入到sql中间表这里要过滤,其实也就是要写访问Excel的sql过滤语句,然后添加到sql表中
展开
 我来答
隐匿望默念
高粉答主

推荐于2019-09-03 · 繁杂信息太多,你要学会辨别
知道答主
回答量:15
采纳率:100%
帮助的人:2076
展开全部

代码如下:

select * from tbl_DPImg where ID in (select min(ID) from tbl_DPImg group by DPID)

处理后结果为:


查找表中多余的重复记录,重复记录是根据单个字段(teamId)来判断

select * from team where teamId in (select teamId from team group by teamId having count(teamId) > 1) 

删除表中多余的重复记录,重复记录是根据单个字段(teamId)来判断,只留有rowid最小的记录 

delete from team where

teamName in(select teamName from team group by teamName having count(teamName) > 1) 

and teamId not in (select min(teamId) from team group by teamName having count(teamName)>1)

扩展资料

数据记录筛选:

sql="select * from 数据表 where字段名=字段值 order by字段名[desc]"(按某个字段值降序排列。默认升序ASC)

sql="select * from 数据表 where字段名like '%字段值%' order by 字段名 [desc]"

sql="select top 10 * from 数据表 where字段名=字段值 order by 字段名 [desc]"

sql="select top 10 * from 数据表 order by 字段名 [desc]"

sql="select * from 数据表 where字段名in ('值1','值2','值3')"

sql="select * from 数据表 where字段名between 值1 and 值2"

参考资料来源:百度百科:SQL语句大全

Andy_Sun321
推荐于2017-09-07 · TA获得超过1376个赞
知道小有建树答主
回答量:811
采纳率:89%
帮助的人:715万
展开全部

使用分析函数row_number() over (partiion by ... order by ...)来进行分组编号,然后取分组标号值为1的记录即可。目前主流的数据库都有支持分析函数,很好用。

其中,partition by 是指定按哪些字段进行分组,这些字段值相同的记录将在一起编号;order by则是指定在同一组中进行编号时是按照怎样的顺序。

示例(SQL Server 2005或以上适用):

select s.*  
from ( 
    select *, row_number() over (partition by [手机号] order by [店铺]) as group_idx  
    from table_name
) s
where s.group_idx = 1
更多追问追答
追问
亲,你太厉害了!!!这些对于sql的表完全没有问题,但是要是用在Excel 表上会出错
追答
Excel好像不能支持的,它不是实际意义上的数据库。就连SQL Server也是2005开始有支持分析函数的。
如果是Excel那么要使用Excel的方式来解决。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
发生等将发生
2014-11-05 · TA获得超过478个赞
知道小有建树答主
回答量:653
采纳率:75%
帮助的人:320万
展开全部
如果仅仅只是查询出来去从,那么就用distinct
select distinct 需要去重的列明(允许多列) from table

如果是需要在表中删除,可以这样处理
1、建立临时表,将重复记录查询出来去重插入到临时表
2、删除实表中的重复记录
3、将临时表中的记录插入到实表
处理完成
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
gy93108083
2014-11-05 · TA获得超过283个赞
知道小有建树答主
回答量:665
采纳率:50%
帮助的人:270万
展开全部
select * into ##tmp_table from 表 where 1=2
declare @PhoneNO int
declare cur cursor for
select 手机号 from 表 group by 手机号
open cur
fetch next from cur into @PhoneNO
while @@fetch_status=0
begin
insert into ##tmp_table
select top 1 from 表 where 手机号=@PhoneNO
fetch next from cur into @PhoneNO
end

select * from ##tmp_table
drop table ##tmp_table
追问
亲,这个有点难,技术水平有限
追答
总体思路就是 把每个 手机号取第一条数据放入临时表,最后查询临时表
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
a18927
2014-11-05 · TA获得超过139个赞
知道小有建树答主
回答量:351
采纳率:0%
帮助的人:196万
展开全部
最简单的 select distinct (手机号)
追问
但是我得整条数据啊  

select distinct (手机号) 只能取到‘手机号’这个字段而已啊
追答
你!!!你在字段后面加其他字段呀,select distinct (手机号),电话 你想要什么字段就加多少字段
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式