注: 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' --列默认值 例如: NULLasbeginIFNOTEXISTS (SELECT *FROM syscolumnsWHERE id = object_id(@tableName)AND NAME = @columnName)BEGINprint 'exec:'+('ALTER TABLE ' + @tableName + ' ADD ' + @columnName + '' + @columnType + '' + @columnDefault)print 'Add['+@columnName+']column'EXEC ('ALTER TABLE ' + @tableName + ' ADD ' + @columnName + '' + @columnType + '' + @columnDefault)ENDIFEXISTS (SELECT *FROM::fn_listextendedproperty('MS_Description', 'SCHEMA' --用户或用户定义类型, N'dbo' --指定的 0 级对象类型的名称, N'TABLE' --1 级对象的类型 , @tableName --指定的 1 级对象类型的名称, N'COLUMN' --2 级对象的类型, @columnName --指定的 2 级对象类型的名称))BEGINprint '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 级对象类型的名称ENDELSEBEGINprint '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 级对象类型的名称ENDendGO

语句:

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

更多相关文章

  1. SQL Server之JSON 函数详解
  2. MySQL 5.7.9 服务无法启动-“NET HELPMSG 3534”的解决方法
  3. MySQL系列多表连接查询92及99语法示例详解教程
  4. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  5. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  6. use ffmpeg to setup streaming server on android
  7. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  8. android中SqLite query中用selectionArgs处理字符传值
  9. android从服务器下载文件(php+apache+win7+MySql)

随机推荐

  1. Android实现无标题栏全屏的方法
  2. Android ListView 去除边缘阴影、选中色
  3. Android(安卓)判断网络连接状态
  4. [Android] ContentProvider实例详解
  5. Android NDK工程的编译和链接调试
  6. Android中的小技巧:TextView限制行数和字
  7. android用户界面之ScrollView教程实例汇
  8. Android屏幕解锁图案破解
  9. Android(安卓)图像处理(类型转换,比例缩放,
  10. android gif动画