SQL批量删除指定数据表中的所有字段说明属性
来源:互联网 发布:淘宝卖家怎么删差评 编辑:程序博客网 时间:2024/06/16 07:34
--SQL批量删除指定数据表中的所有字段说明属性
--现象:执行select * from sys.extended_properties where value is null;显示出多条记录类似于[1 OBJECT_OR_COLUMN 2372069 1 MS_Description NULL]
--操作:执行delete from sys.extended_properties where value is null;提示[不允许对系统目录进行即席更新]
--功能说明:因为错误的操作将到了字段描述为NULL添加到系统数据表sys.extended_properties中,最终需要批量删除掉后再添加字段描述
declare @TableName nvarchar(250)--定义当前操作的数据表名变量
set @TableName='user'--指定要查询的数据表名称(此处的数据表名user需要更新为你的数据库中的已有数据表名)
declare @ColumnName nvarchar(250)--游标中的当前查询的字段名称
declare @ColumnDescription nvarchar (250)--游标中的当前查询的字段说明
--声明读取数据表中所有字段说明的游标
declare mycursor cursor for select a.name,CAST(g.value AS nvarchar) from sys.columns a left join sys.extended_properties g on (a.object_id = g.major_id AND a.column_id=g.minor_id) where object_id=OBJECT_ID(''+@TableName+'') order by object_id,a.column_id
--打开游标
open mycursor
--从游标里取出数据赋值到约束名称变量中
fetch next from mycursor into @ColumnName,@ColumnDescription
--如果游标执行成功
while (@@fetch_status=0)
begin
if(@ColumnDescription is null)
begin
print '当前数据表['+@TableName+']字段['+@ColumnName+']对应的说明为空'
--删除字段的描述属性值为NULL的记录
--EXEC sp_dropextendedproperty 'MS_Description','user',dbo,'table','数据表名称', 'column','字段名称'
EXEC sp_dropextendedproperty 'MS_Description','user',dbo,'table',@TableName,'column',@ColumnName
end
else
begin
--查询当前找到的字段说明
print '当前数据表['+@TableName+']字段['+@ColumnName+']对应的说明是['+@ColumnDescription+']'
end
--用游标去取下一条记录
fetch next from mycursor into @ColumnName,@ColumnDescription
end
--关闭游标
close mycursor
--撤销游标
deallocate mycursor
- SQL批量删除指定数据表中的所有字段说明属性
- SQL读取指定数据表中的所有字段说明
- SQL批量删除数据表中指定字段对应的所有约束
- sql 获取指定数据表的所有字段名称的字符串
- SQL获取指定数据表所有字段类型和精度脚本
- mysql批量删除指定后缀名的数据表
- SQL批量更新数据库中所有用户数据表中字段类型为tinyint为int
- SQL删除字段中所有内容中的第一个字符
- SQL删除指定字段问题
- 修改mysql数据表中的字段属性
- SQL2005批量删除字段说明描述
- winfrom SQL server 控件Listbox 输出数据表中的所有行和指定列
- T-SQL分割数据表中的字段
- 批量替换 MySQL 指定字段中的字符串
- 批量替换 MySQL 指定字段中的字符串
- 批量替换 MySQL 指定字段中的字符串
- 批量替换 MySQL 指定字段中的字符串
- 批量替换 MySQL 指定字段中的字符串
- vim中设置pig高亮
- 数组作为函数参数进行传递
- IDFTP获取ftp文件列表中文乱码的解决办法
- Spring启动<二>——XmlWebApplicationContext
- corc::socket+coro::handle server-echo server
- SQL批量删除指定数据表中的所有字段说明属性
- 【FTP】批处理实现用FTP服务器上的文件更新本机文件 .
- Linux或Windows下 改变Tomcat JVM 内存设置方法
- How to debug a program(1)
- java——封装
- 关于SIGSEGV错误及处理方法
- 离线安装Android SDK
- 站长常用的12个源码类下载网站
- Spring启动<三>——XmlWebApplicationContext