如何批量修改数据库中不同字段中相同的值

如何批量修改数据库中不同字段中相同的值,第1张

use test --修改为你的数据库名称

declare tb_name cursor for select NAME,ID from sysobjects WHERE TYPE='U' --得到用户表的ID

declare @in_char varchar(20)

set @in_char='%<script>%' ---查找注入字符串

declare @tj varchar(5000)

set @tj=' where '

declare @i int

set @i=0

declare @sql varchar(200)

DECLARE @table_name varchar(50)

DECLARE @table_id varchar(50)

DECLARE @feild_name varchar(50)

DECLARE @fd_count int

open tb_name

FETCH next FROM tb_name into @table_name,@table_id

while @@FETCH_STATUS=0

begin

set @i=0

declare fd_name cursor for SELECT NAME FROM syscolumns where id=@table_id and type=39 group by name--得到用户表某一ID的所有字符类型字段名称

open fd_name

FETCH next FROM fd_name into @feild_name

print @fd_count

while @@FETCH_STATUS=0

begin

set @i=@i+1

set @tj=@tj+@feild_name +' like '''+ @in_char +'''' +(case when (SELECT count(type) as fd_count FROM syscolumns where id=@table_id and type=39)

>@i then ' or ' else ' 'end)

FETCH next FROM fd_name into @feild_name

end

-- print @tj

if @tj!=''

begin

SET @SQL='DELETE FROM '+@TABLE_NAME+@TJ

print '切记先运行代码看print 出来的SQL确认后再删除数据,即将运行的代码是 '

print '===================================================================='

print @SQL

print '===================================================================='

--切记先运行代码看print 出来的SQL确认后再删除数据

exec(@sql) --修改注释后删除数据

end

set @tj=''

CLOSE fd_name

deallocate fd_name

FETCH next FROM tb_name into @table_name,@table_id

end

close tb_name

deallocate tb_name

下面以 sqlserver数据库为例进行说明。

select from TableA where b in (select  b from  TableA group  by  b having  count(b) > 1)

这样就列举出了b字段所有的重复数据,可以根据对应的行号,取得位于第几行。

如果要查询a字段或者c字段重复数据,可以相应的把上面的b字段替换成a字段或c字段即可。

举例:

1、创建表student

2、查询语句: select from student where name in (select  name from  student group  by  name   having  count(name ) > 1)

这样就查出名字重复列,以及行号id。

扩展资料:

1 sqlserver其他相关的一些查询:

(1)删除表中多余的重复记录,重复记录是根据单个字段(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)

(2)查找表中多余的重复记录(多个字段) 

select from vitae a where (apeopleId,aseq) in

(select peopleId,seq from vitae group by peopleId,seq having count() > 1)

(3)查找表中多余的重复记录(多个字段),不包含rowid最小的记录

select from vitae a where (apeopleId,aseq)  in

(select peopleId,seq from vitae group by peopleId,seq havingcount() > 1) and

rowid not in (select min(rowid) from vitae group by peopleId,seq having count()>1)

2 SQL语言元素

1、子句,是语句和查询的组成部分。

2、表达式,可以生成标量值,也可以生成由列和行数据组成的表。

3、谓词,指定可以评估为SQL三值逻辑(3VL)(真/假/未知)或布尔真值的条件,用于限制语句和查询的效果,或用于更改程序流。

4、查询,根据特定条件检索数据。这是SQL的一个重要元素。

语句可能对架构和数据产生持久影响,或者可能控制事务,程序流,连接,会话或诊断。

SQL语句还包括分号(“;”)语句终止符。虽然并非每个平台都需要,但它被定义为SQL语法的标准部分。在SQL语句和查询中通常会忽略无关紧要的空格,从而可以更轻松地格式化SQL代码以提高可读性。

参考资料:

百度百科-SQL语法

我如果请教别人问题,会这样提问

假如:有张表, 字段为结果为

-------------------------

id   name   tid  cid  fid

1    张三    2    3    4

2    李四    1    4    3

3    王五    2    2    4

像 王五 tid 与 cid 值相同,则被选取,而其他不被选取

不然谁知道你问什么

以上就是关于如何批量修改数据库中不同字段中相同的值全部的内容,包括:如何批量修改数据库中不同字段中相同的值、怎么查看数据库表中某个字段的值有哪些重复记录、MySQL统计同表中多个字段下相同的值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10169590.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存