SQL Server数据库表中怎么添加列和描述
Admin 2022-06-20 群英技术资讯 646 次浏览
注: sql server 2005 及以上支持. 版本估计是不支持(工作环境2005,2008).
工作需要, 需要向SQL Server 现有表中添加新列并添加描述. 从而有个如下存储过程. (先附上存储过程然后解释)
/********调用方法********** 作用: 添加列并添加列描述信息 调用: exec [SetColumnInfo] '表名', '列名', N'列说明,描述','列类型{默认:NVARCHAR(50)}','列默认值{默认:NULL}' ******************/ CREATEPROCEDURE [dbo].[SetColumnInfo] @tableName NVARCHAR(100) --表名 ,@columnName NVARCHAR(100) --列名 ,@columnInfo NVARCHAR(2000) --列说明,描述 ,@columnType NVARCHAR(100)='NVARCHAR(50)' --列类型 例如: NVARCHAR(50) ,@columnDefault NVARCHAR(100)='NULL' --列默认值 例如: NULL as begin IFNOTEXISTS ( SELECT * FROM syscolumns WHERE id = object_id(@tableName) AND NAME = @columnName ) BEGIN print 'exec:'+('ALTER TABLE ' + @tableName + ' ADD ' + @columnName + '' + @columnType + '' + @columnDefault) print 'Add['+@columnName+']column' EXEC ('ALTER TABLE ' + @tableName + ' ADD ' + @columnName + '' + @columnType + '' + @columnDefault) END IFEXISTS ( SELECT * FROM::fn_listextendedproperty('MS_Description', 'SCHEMA' --用户或用户定义类型 , N'dbo' --指定的 0 级对象类型的名称 , N'TABLE' --1 级对象的类型 , @tableName --指定的 1 级对象类型的名称 , N'COLUMN' --2 级对象的类型 , @columnName --指定的 2 级对象类型的名称 ) ) BEGIN print 'Edit['+@columnName+']Description' EXEC sys.sp_updateextendedproperty @name = N'MS_Description' --要添加的属性名称 ,@value = @columnInfo --将要与属性相关联的值 ,@level0type = N'SCHEMA' --用户或用户定义类型 ,@level0name = N'dbo' --指定的 0 级对象类型的名称 ,@level1type = N'TABLE' --1 级对象的类型 ,@level1name = @tableName --指定的 1 级对象类型的名称 ,@level2type = N'COLUMN' --2 级对象的类型 ,@level2name = @columnName --指定的 2 级对象类型的名称 END ELSE BEGIN print 'Add['+@columnName+']Description' EXEC sys.sp_addextendedproperty @name = N'MS_Description' --要添加的属性名称 ,@value = @columnInfo --将要与属性相关联的值 ,@level0type = N'SCHEMA' --用户或用户定义类型 ,@level0name = N'dbo' --指定的 0 级对象类型的名称 ,@level1type = N'TABLE' --1 级对象的类型 ,@level1name = @tableName --指定的 1 级对象类型的名称 ,@level2type = N'COLUMN' --2 级对象的类型 ,@level2name = @columnName --指定的 2 级对象类型的名称 END end GO
解释:
语句:
SELECT * FROM syscolumns WHERE id = object_id(@tableName) AND NAME = @columnName
作用: 查找表中是否存在指定的列. 如果存在则添加会报错.
ALTER TABLE 语句:
ALTER TABLE 语句用于在已有的表中添加、修改或删除列。
如需在表中添加列,请使用下列语法:
ALTERTABLE table_name ADD column_name datatype
要删除表中的列,请使用下列语法:
ALTERTABLE table_name DROPCOLUMN column_name
要改变表中列的数据类型,请使用下列语法:
ALTERTABLE table_name ALTERCOLUMN column_name datatype
属性的增删改:
fn_listextendedproperty: 获取扩展属性, 主要判断下属性是否存在如果存在则更新, 不存在则添加
sp_updateextendedproperty: 更新字段描述
sp_addextendedproperty : 添加字段描述
sp_dropextendedproperty: 删除字段描述
因为sp_dropextendedproperty上文存储过程没有出现特附上示例:
EXECsp_dropextendedproperty 'MS_Description','user',dbo,'table','表','column',a1
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文接下来讲解的是MySQL的隐式转换,对此感兴趣的小伙伴很可以一起来看看
sql怎么创建约束?在SQL Server中有五种约束,分别是Primary Key约束、Foreign Key约束、Unique约束、Default约束和Check约束。对于新手来说,不是很了解约束的创建和使用,对此,下面就给大家介绍一下。
前言上几篇文章我们介绍了如何查看查询计划、常用运算符的介绍、并行运算的方式,有兴趣的可以点击查看。本篇将分析在SQLServer中,如何利用先有索引项进行查询性能优...
最近服务器执行收缩日志文件大小的job老是报错,小编抽时间把此问题的解决方案整理了一下,特此分享到脚本之家平台,供大家学习
在实际的工作中,尤其是在生产环境里边,SQL语句的优化问题十分的重要,它对数据库的性能的提升也起着显著的作用.我们总是在抱怨机器的性能问题,总是在抱怨并发访问所带来的琐问题,但是如果我们对没一条SQL语句进行优化,尽管不能说可以解决全部问题
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008