注: sql server 2005 及以上支持. 版本估计是不支持(工作环境2005,2008).
工作需要, 需要向SQL Server 现有表中添加新列并添加描述. 从而有个如下存储过程. (先附上存储过程然后解释)
/********调用方法**********
作用: 添加列并添加列描述信息
调用:
exec [SetColumnInfo] '表名', '列名', N'列说明,描述','列类型{默认:NVARCHAR(50)}','列默认值{默认:NULL}'
******************/ CREATE PROCEDURE [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 IF NOT EXISTS (
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 IF EXISTS (
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 语句用于在已有的表中添加、修改或删除列。
如需在表中添加列,请使用下列语法:
要删除表中的列,请使用下列语法:
要改变表中列的数据类型,请使用下列语法:
属性的增删改:
fn_listextendedproperty: 获取扩展属性, 主要判断下属性是否存在如果存在则更新, 不存在则添加
sp_updateextendedproperty: 更新字段描述
sp_addextendedproperty: 添加字段描述
sp_dropextendedproperty: 删除字段描述
因为sp_dropextendedproperty上文存储过程没有出现特附上示例:
EXECsp_dropextendedproperty 'MS_Description','user',dbo,'table','表','column',a1
向SQL Server 现有表中添加新列并添加描述.的更多相关文章
-
sql server 关于表中只增标识问题 C# 实现自动化打开和关闭可执行文件(或 关闭停止与系统交互的可执行文件) ajaxfileupload插件上传图片功能,用MVC和aspx做后台各写了一个案例 将小写阿拉伯数字转换成大写的汉字, C# WinForm 中英文实现, 国际化实现的简单方法 ASP.NET Core 2 学习笔记(六)ASP.NET Core 2 学习笔记(三)
sql server 关于表中只增标识问题 由于我们系统时间用的过长,数据量大,设计是采用自增ID 我们插入数据的时候把ID也写进去,我们可以采用 关闭和开启自增标识 没有关闭的时候 ,提示一下错 ...
-
SQL语句 在一个表中插入新字段
SQL语句 在一个表中插入新字段: alter table 表名 add 字段名 字段类型 例: alter table OpenCourses add Audio varchar(50)alter ...
-
EF Core中,通过实体类向SQL Server数据库表中插入数据后,实体对象是如何得到数据库表中的默认值的
我们使用EF Core的实体类向SQL Server数据库表中插入数据后,如果数据库表中有自增列或默认值列,那么EF Core的实体对象也会返回插入到数据库表中的默认值. 下面我们通过例子来展示,EF ...
-
将文件导入到SQL server数据库表中的字段中
一.在要执行的sql server数据库a中执行如下脚本,创建存储过程sp_textcopy /* 将二进制文件导入.导出到数据库相应字段列中 */ CREATE PROCEDURE sp_textc ...
-
SQL Server现有表上自增属性增删原理研究
项目需求:线上有一张表,数据类型为int类型,现在由于项目变更,需要这一列添加自增属性,而且,为了保证能尽快完成,希望使用脚本来实现,而不是在表设计中通过GUI窗口来实现. 问题来了:SQL Serv ...
-
SQL SERVER 将表中字符串转换为数字的函数 (详询请加qq:2085920154)
在SQL SERVER 2005中,将表中字符串转换为数字的函数共2个:1. convert(int,字段名) 例如:select convert(int,'3')2. cast(字段名 as i ...
-
SQL Server 判断表中是否存在某字段
功能:判断表中是否存在某字段,若不存在,则新增该字段 语句: IF NOT EXIST (SELECT 1 FROM [DATABASE].[SCHEMA].SYSCOLUMNS WHERE ID=O ...
-
SQL Server 用表中已有数据造数据
从表中选择数据再插入到表中(select XXX into 与insert into XXX select的结合) 在做性能测试时需要大量的业务数据.完全从画面造数据比较费时间,使用SQL文批量插入数 ...
-
SQL Server 将一个表中字段的值复制到另一个表的字段中
具体方法如下 一:update 表2 set (要插入的列名)= select 表1.某一列 from 表1 left jion 表2 on 表1和表2的关联 where ..... 二:update ...
随机推荐
-
android 网络通讯
//get方式请求网络数据 String urlPath="http://192.168.98.112:8080/CloudMusicPlayer/fragment1_1_lv2/json/ ...
-
网易云课堂_C++开发入门到精通_章节4:运算符重载
课时23运算符重载 运算符重载 重载赋值运算符 Person& Person::operator=(const Person& other) { //检查自赋值 if (this == ...
-
js cookie读取
/**存放Cookies: 两个参数,一个是cookie的名子,一个是值*/ function SetCookie(name,value){ var Days = 30; //此 cookie 将被保 ...
-
why-and-howto-calculate-your-events-per-second
http://eromang.zataz.com/2011/04/12/why-and-howto-calculate-your-events-per-second/
-
validform表单验证插件最终版
做个笔记,以后直接用吧. 报名界面: <%@ page language="java" pageEncoding="UTF-8" contentType= ...
-
==和equals详解+例子
一开始遇见==和equals我也是分不清,后来看了很多博客,收益匪浅, 担心以后给忘了,所以写下这个,以后复习可以用. (有哪里写得不对的,希望可以留言帮忙改进,大家一起共同进步) 一.Java数据类 ...
-
配置CLion作为Qt5开发环境
使用Qt进行程序开发时QtCreator总是不二之选.作为老牌IDE在提供了强大的功能同时也对Qt的支持做了许多优化.如果没有特别的原因你应该使用它. 然而一个顺手的工具将会极大得提升生产效率,而如果 ...
-
解决SkyP2M工程常见问题所参考的博客汇总
工程是基于64位的 1 Error 26 error C2491: 'HUDManager::_viewport' : definition of dllimport static data memb ...
-
Markdown简单上手
标题 # +内容 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 字体 1. 加粗(Ctrl+B) **加粗** 2. 斜体(Ctrl+I) *斜体* 3. 斜体加粗(Ctrl+B+I) ...
-
Java中的并发工具类(CountDownLatch、CyclicBarrier、Semaphore、Exchanger)
在JDK的并发包里提供了很多有意思的并发工具类.CountDownLatch.CyclicBarrier和Semaphore 工具类提供了一种并发流程控制的手段,Exchanger 工具类则提供了在线 ...