asp中怎么在关联查询中去除重复的记录 25

A表(客户信息表)ID(客户ID)kname(客户名称)1客户12客户23客户3B表(客户跟进信息表)ID(跟进记录ID)k_id(对应客户信息表的ID)genjin(跟... A表(客户信息表)
ID(客户ID) kname(客户名称)
1 客户1
2 客户2
3 客户3

B表(客户跟进信息表)
ID(跟进记录ID) k_id(对应客户信息表的ID) genjin(跟进内容)
5 1 根据内容1
6 1 根据内容2
7 1 根据内容3
6 2 根据内容4

我想根据(客户跟进信息表)的ID进行排序出最近的根据客户,并且去除重复的记录,SQL该怎么写?

我之前是SQL语句是这样select A.* from A inner join B on A.ID=B.k_id where order by B.ID DESC
但是有重复,请大侠帮助下
展开
 我来答
清净脦自在
2014-09-28 · 超过33用户采纳过TA的回答
知道答主
回答量:94
采纳率:50%
帮助的人:23.7万
展开全部
你这个不应该asp 而是sql:
SQL DISTINCT重复的数据统计方法 group by 重复数据的个数统计 删除重复的数据2008-09-10 16:30DISTINCT 关键字可从 SELECT 语句的结果中除去重复的行。如果没有指定 DISTINCT,那么将返回所有行,包括重复的行。
select count(distinct t.destaddr) from nbyd_send t where t.input_time > to_date('2007-2-1','yyyy-mm-dd') and t.input_time < to_date('2007-3-1','yyyy-mm-dd')

可以统计出一个月中的用户数量。

关于如何快速得知里面每一个号码重复的个数问题的解答:利用分组函数的SQL语句
select t.tel,count(*) from nbyd_deliver t group by t.tel ;group by 解决重复数据的个数统计适用于各种关系型数据库,如oracle,SQL Server

查询重复的数据
select * from (select v.xh,count(v.xh) num from sms.vehicle v group by v.xh) where num>1;--169

select v.xh,count(v.xh) num from sms.vehicle v group by v.xh having count(v.xh)=2;

删除重复的数据

create table mayong as (select distinct* from sms.vehicle);

delete from sms.vehicle ;

insert into sms.vehicle select * from mayong;

在oracle中,有个隐藏了自动rowid,里面给每条记录一个唯一的rowid,我们如果想保留最新的一条记录,我们就可以利用这个字段,保留重复数据中rowid最大的一条记录就可以了。

下面是查询重复数据的一个例子:

select a.rowid,a.* from 表名 a
where a.rowid !=
(
select max(b.rowid) from 表名 b
where a.字段1 = b.字段1 and
a.字段2 = b.字段2
)
上面括号中的语句是查询出重复数据中rowid最大的一条记录。

而外面就是查询出除了rowid最大之外的其他重复的数据了。
由此,我们要删除重复数据,只保留最新的一条数据,就可以这样写了:
delete from 表名 a
where a.rowid !=
(
select max(b.rowid) from 表名 b
where a.字段1 = b.字段1 and
a.字段2 = b.字段2
)

随便说一下,上面语句的执行效率是很低的,可以考虑建立临时表,讲需要判断重复的字段、rowid插入临时表中,然后删除的时候在进行比较。
create table 临时表 as
select a.字段1,a.字段2,MAX(a.ROWID) dataid from 正式表 a GROUP BY a.字段1,a.字段2;
delete from 表名 a
where a.rowid !=
(
select b.dataid from 临时表 b
where a.字段1 = b.字段1 and
a.字段2 = b.字段2
);
commit;

二、对于完全重复记录的删除

对于表中两行记录完全一样的情况,可以用下面语句获取到去掉重复数据后的记录:
select distinct * from 表名
可以将查询的记录放到临时表中,然后再将原来的表记录删除,最后将临时表的数据导回原来的表中。如下:
CREATE TABLE 临时表 AS (select distinct * from 表名);
delete from table 正式表;
insert into 正式表 (select * from 临时表);
drop table 临时表;
追问
能针对我的例子,写个具体的SQL语句吗
l460660436
2014-09-28 · TA获得超过369个赞
知道小有建树答主
回答量:445
采纳率:100%
帮助的人:199万
展开全部
用distinct试下。
追问
能写个具体的SQL语句看看吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
mnbvcxzsl
2014-09-28 · TA获得超过307个赞
知道答主
回答量:50
采纳率:0%
帮助的人:27.3万
展开全部
select a.* from A as a, B as b where A.ID=B.k_id order by B.ID DESC
更多追问追答
追问

根据你的方法还是和我之前的SQL语句一样的结果,有重复

追答
select distinct a.* from A as a, B as b where A.ID=B.k_id  order by B.ID DESC
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式