删除指定名称的所有字段.sql

本文介绍如何使用SQL脚本批量删除指定表中的指定列名和数据类型字段,包括通过变量设置列名和数据类型,以及利用foreach循环遍历所有表执行删除操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--要删除的列名
DECLARE @fieldname sysname
SET @fieldname='id'

--删除处理
DECLARE @command nvarchar(2000),@whereand nvarchar(2000)
SELECT @command=N'ALTER TABLE ? DROP COLUMN '
  +QUOTENAME(@fieldname),
 @whereand=N'AND EXISTS(SELECT * FROM syscolumns WHERE id=o.id AND name='
  +QUOTENAME(@fieldname,N'''')+N')'
EXEC sp_MSforeachtable @command1=@command,@whereand=@whereand
(2)删除所有表中指定类型的字段。
--要删除的列的数据类型
DECLARE @fieldtype sysname
SET @fieldtype='varchar'

--删除处理
DECLARE hCForEach CURSOR GLOBAL
FOR
SELECT N'ALTER TABLE '+QUOTENAME(o.name)
 +N' DROP COLUMN '+QUOTENAME(c.name)
FROM sysobjects o,syscolumns c,systypes t
WHERE o.id=c.id
 AND OBJECTPROPERTY(o.id,N'IsUserTable')=1
 AND c.xusertype=t.xusertype
 AND t.name=@fieldtype
EXEC sp_MSforeach_Worker @command1=N'?'

转载于:https://www.cnblogs.com/dushu/archive/2012/06/03/2532756.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值