一个简单的去除重复字段的SQL查询语句.doc

上传人:ni****g 文档编号:560616222 上传时间:2023-10-12 格式:DOC 页数:13 大小:190KB
返回 下载 相关 举报
一个简单的去除重复字段的SQL查询语句.doc_第1页
第1页 / 共13页
一个简单的去除重复字段的SQL查询语句.doc_第2页
第2页 / 共13页
一个简单的去除重复字段的SQL查询语句.doc_第3页
第3页 / 共13页
一个简单的去除重复字段的SQL查询语句.doc_第4页
第4页 / 共13页
一个简单的去除重复字段的SQL查询语句.doc_第5页
第5页 / 共13页
点击查看更多>>
资源描述

《一个简单的去除重复字段的SQL查询语句.doc》由会员分享,可在线阅读,更多相关《一个简单的去除重复字段的SQL查询语句.doc(13页珍藏版)》请在金锄头文库上搜索。

1、一个简单的去除重复字段的SQL查询语句 2009-11-16 17:12一个简单的去除重复字段的SQL查询语句2008-11-04 16:01:15 by rainoxu | 分类:我的知识库今天公司里让.Net程序修改一个程序,需要去掉输出中的重复楼盘名称,一开始想到的是Distinct,但死路不通,只能改道,最终偶在网上找到了一个思路,修改了一下就有了。先看所有记录(这是我在测试的数据库里做的):OK,我们这样来消除重复项:1. select * from table1 as a where not exists(select 1 from table1 where logID=a.Log

2、ID and IDa.ID)2.最近做一个数据库的数据导入功能,发现联合主键约束导致不能导入,原因是源表中有重复数据,但是源表中又没有主键,很是麻烦。经过努力终于解决了,现在就来和大家分享一下,有更好的办法的可以相互交流。有重复数据主要有一下几种情况:1.存在两条完全相同的纪录这是最简单的一种情况,用关键字distinct就可以去掉example: select distinct * from table(表名) where (条件)2.存在部分字段相同的纪录(有主键id即唯一键)如果是这种情况的话用distinct是过滤不了的,这就要用到主键id的唯一性特点及group by分组exampl

3、e:select * from table where id in (select max(id) from table group by 去除重复的字段名列表,.)3.没有唯一键ID这种情况我觉得最复杂,目前我只会一种方法,有那位知道其他方法的可以留言,交流一下:example:select identity(int1,1) as id,* into newtable(临时表) from tableselect * from newtable where id in (select max(id) from newtable group by 去除重复的字段名列表,.)drop table

4、newtable关于一个去除重复记录的sql语句 2009-8-24 16:33 提问者:lichuanbao1234 | 悬赏分:30 | 浏览次数:1075次我要查询一个表中content字段相同的记录的详细信息。其中每条记录都有一个标识符state,0表示未发送,1表示已发送。我要统计所有content相同的记录的信息,包括其中已发送(state=1)的记录。请问大家看看我这样写有什么问题?select distinct content,name,push_date,total,e.total_sended from tbl_jingwei_push a,(select count(*)

5、 as total_sended from tbl_jingwei_push where state=1 and content=a.content) e这样查出的其他字段都是符合要求的,唯独e.total_sended的结果出问题,它显示的是表中所有state=1的记录,请问大家我要怎么改呢?问题补充: 这个sql语句是不对的。表a是错误的。请大家指点迷津,我要统计content相同并且state为1的记录数目。谢谢各位 。我就是想去掉重复记录并统计一下,只不过如果state=1的话,我要统计一下state=1的记录数。前提是这些记录的content是相同的。二楼回答的不对,这和我写的是一样

6、的,a表是不能在e表中用的。2009-8-24 16:57 最佳答案 select distinct content,name,push_date,total,sum(case state when 1 then 1 when 0 then 0 end) as total_sended from tbl_jingwei_push 以上,希望对你有所帮助!select distinct content,name,push_date,total,e.total_sended from tbl_jingwei_push a,(select count(*) as total_sended from

7、tbl_jingwei_push where state=1 and e.content=a.content) e 赞同0| 评论 2009-8-24 16:54 hrhero | 五级 select distinct content,name,push_date,total,e.total_sended from tbl_jingwei_push a,(select count(*) as total_sended from tbl_jingwei_push where state=1 and content=a.content group by content ) e试试这样SQLServ

8、er:Distinct和Group by去除重复字段记录2010-10-14 11:31:27|分类: 默认分类 |标签: |字号大中小订阅 重复记录 有两个意义,一是完全重复的记录,也即所有字段均重复的记录 二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。1、对于第一种重复,比较容易解决,使用select distinct * from tableName就可以得到无重复记录的结果集。如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除select distinct * into #Tmp from tableNamedrop table

9、 tableNameselect * into tableName from #Tmpdrop table #Tmp发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。2、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集select identity(int,1,1) as autoID, * into #Tmp from tableNameselect min(autoID) as autoID into #Tmp2 from #Tmp group by Nameselect * from #Tm

10、p where autoID in(select autoID from #tmp2)最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)其它的数据库可以使用序列,如:create sequence seq1;select seq1.nextval as autoID, * into #Tmp from tableName=zuolo: 我根据上面实例得到所需要的语句为 SELECT MAX(id) AS ID,Prodou_id,FinalDye FROM anwell.tblDBDdata GROUP

11、BY Prodou_id,FinalDye ORDER BY id,之前一直想用Distinct来得到指定字段不重复的记录是个误区。如何写一个SQL语句,能检索出所有某个字段内容有重复的记录A : 比如: Name Adress Tele 1 Yao China 110 2 Zhang Moon 110 3 Wang China 110 4 Wang China 110 5 Yao China 110 根据姓名字段检索以后,能筛选出的记录有:1,3,4,5 select b.id from table as b,(select count(field),field from table whe

12、re count(field)2 group by field) as a where a.field=b.field SELECT id from tb where dcount(id,tb,name=&name&)1 附: DCount Function See Also Specifics You can use the DCount function to determine the number of records that are in a specified set of records (a domain). Use the DCount function in Visual

13、 Basic, a macro, a query expression, or a calculated control. For example, you could use the DCount function in a module to return the number of records in an Orders table that correspond to orders placed on a particular date. DCount(expr, domain, criteria) The DCount function has the following argu

14、ments. Argument Description expr An expression that identifies the field for which you want to count records. It can be a string expression identifying a field in a table or query, or it can be an expression that performs a calculation on data in that field. In expr, you can include the name of a field in a table, a control on a form, a constant, or a function. If expr includes a fun

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号