最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

SQL批量删除指定数据表中的所有字段说明属性

来源:懂视网 责编:小采 时间:2020-11-09 10:55:06
文档

SQL批量删除指定数据表中的所有字段说明属性

SQL批量删除指定数据表中的所有字段说明属性:declare @TableName nvarchar(250)--定义当前操作的数据表名变量set @TableName= --SQL批量删除指定数据表中的所有字段说明属性 --现象:执行select * from sys.extended_properties where value is null;显示出多条
推荐度:
导读SQL批量删除指定数据表中的所有字段说明属性:declare @TableName nvarchar(250)--定义当前操作的数据表名变量set @TableName= --SQL批量删除指定数据表中的所有字段说明属性 --现象:执行select * from sys.extended_properties where value is null;显示出多条

declare @TableName nvarchar(250)--定义当前操作的数据表名变量set @TableName=

--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

linux

文档

SQL批量删除指定数据表中的所有字段说明属性

SQL批量删除指定数据表中的所有字段说明属性:declare @TableName nvarchar(250)--定义当前操作的数据表名变量set @TableName= --SQL批量删除指定数据表中的所有字段说明属性 --现象:执行select * from sys.extended_properties where value is null;显示出多条
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top