1. sql中多个字段同时相同的多余记录删除!
如果c和d里面没有一个类似id这样的唯一列,除非用游标,否则单sql做不到
delete from A a1
WHERE EXISTS(SELECT 1 FROM A WHEE a = a1.a and b = a1.b and c > a1.c)
这样删除的是a,b相同只保留c最大的那条
2. SQL删除多个字段下所有内容
delete 一般用于整行删除。
要删除一行中的部分字段可以用UPDATE
UPDATE tcinfor SET tc_work_jx =null , tc_work_ky =null , tc_work_xsh =null
3. SQL重复记录查询 查询多个字段、多表查询、删除重复记录的方法
SQL重复记录查询
1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断
select
*
from
people
where
peopleId
in
(select
peopleId
from
people
group
by
peopleId
having
count(peopleId)
>
1)
例二:
select
*
from
testtable
where
numeber
in
(select
number
from
people
group
by
number
having
count(number)
>
1
)
可以查出testtable表中number相同的记录
2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录
delete
from
people
where
peopleId
in
(select
peopleId
from
people
group
by
peopleId
having
count(peopleId)
>
1)
and
rowid
not
in
(select
min(rowid)
from
people
group
by
peopleId
having
count(peopleId
)>1)
3、查找表中多余的重复记录(多个字段)
select
*
from
vitae
a
where
(a.peopleId,a.seq)
in
(select
peopleId,seq
from
vitae
group
by
peopleId,seq
having
count(*)
>
1)
4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录
delete
from
vitae
a
where
(a.peopleId,a.seq)
in
(select
peopleId,seq
from
vitae
group
by
peopleId,seq
having
count(*)
>
1)
and
rowid
not
in
(select
min(rowid)
from
vitae
group
by
peopleId,seq
having
count(*)>1)
5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录
select
*
from
vitae
a
where
(a.peopleId,a.seq)
in
(select
peopleId,seq
from
vitae
group
by
peopleId,seq
having
count(*)
>
1)
and
rowid
not
in
(select
min(rowid)
from
vitae
group
by
peopleId,seq
having
count(*)>1)
(二)
比方说
在A表中存在一个字段“name”,
而且不同记录之间的“name”值有可能会相同,
现在就是需要查询出在该表中的各记录之间,“name”值存在重复的项;
Select
Name,Count(*)
From
A
Group
By
Name
Having
Count(*)
>
1
如果还查性别也相同大则如下:
Select
Name,sex,Count(*)
From
A
Group
By
Name,sex
Having
Count(*)
>
1
(三)
方法一
declare
@max
integer,@id
integer
declare
cur_rows
cursor
local
for
select
主字段,count(*)
from
表名
group
by
主字段
having
count(*)
>;
1
open
cur_rows
fetch
cur_rows
into
@id,@max
while
@@fetch_status=0
begin
select
@max
=
@max
-1
set
rowcount
@max
delete
from
表名
where
主字段
=
@id
fetch
cur_rows
into
@id,@max
end
close
cur_rows
set
rowcount
0
方法二
有两个意义上的重复记录,一是完全重复的记录,也即所有字段均重复的记录,二是部分关键字段重复的记录,比如Name字段重复,而其他字段不一定重复或都重复可以忽略。
1、对于第一种重复,比较容易解决,使用
select
distinct
*
from
tableName
就可以得到无重复记录的结果集。
如果该表需要删除重复的记录(重复记录保留1条),可以按以下方法删除
select
distinct
*
into
#Tmp
from
tableName
drop
table
tableName
select
*
into
tableName
from
#Tmp
drop
table
#Tmp
发生这种重复的原因是表设计不周产生的,增加唯一索引列即可解决。
2、这类重复问题通常要求保留重复记录中的第一条记录,操作方法如下
假设有重复的字段为Name,Address,要求得到这两个字段唯一的结果集
select
identity(int,1,1)
as
autoID,
*
into
#Tmp
from
tableName
select
min(autoID)
as
autoID
into
#Tmp2
from
#Tmp
group
by
Name,autoID
select
*
from
#Tmp
where
autoID
in(select
autoID
from
#tmp2)
最后一个select即得到了Name,Address不重复的结果集(但多了一个autoID字段,实际写时可以写在select子句中省去此列)
(四)
查询重复
select
*
from
tablename
where
id
in
(
select
id
from
tablename
group
by
id
having
count(id)
>
1
)
以上就是小编为大家带来的SQL重复记录查询
查询多个字段、多表查询、删除重复记录的方法的全部内容了,希望对大家有所帮助,多多支持脚本之家~
4. SQL 如何删除单个表中3或多个个字段重复的记录
根据多个字段分组查询出各自最小的id,删除除了这些id外的其他数据delete
from
table1
a
where
a.id not
in(
select
min(a1.id)
from
table1
a1
where
group
by
字段1,字段2,字段3。。。)
5. 在sql中如何给多个字段去重
select max(部门) as 部门,姓名,sum(金额) as 金额 from 表名
group by 姓名
6. 清空一个表下面的某个字段的SQL语句
方法一,设置B为空
update A set B = null;
方法二,删除B字段后重建
alter table A drop column B;
alter table A add B varchar(50);
7. SQL如何用语句清空某表某字段的值
SQL我不懂 但是原理的话,设置对应的字段允许空字符串,然后在页面上用更新数据库的方法,把那个字段的值更新成空值
8. 如何使sql数据清零
你好,很高兴回答你的问题。
如果问题所说的清零是把指定字段的值设置成0,那就是使用update语句进行更新这个字段的值。
如果问题所说的清零是把表中的数据删除掉,那就是使用delete语句进行数据删除。
如果有帮助到你,请点击采纳。
9. sql 清空多个表
delete from table1,table2,table3 --这是把表里的记录全部删除
update table1 --这个是把某些字段变成空值
set [字段1] = null --我也没试过 不知道好不好用
,[字段2] = null --前提条件是 表的字段不能设为 ‘不允许为空’
不知道你说的' 内容 ' 是为空啊? 还是删除啊?
10. 怎样清空SQL表里指定字段的内容
update gx set body=null