1:增加字段

语法:alter table 表名 add 新增字段名 字段类型 默认值…
2:修改字段名

语法:exec sp_rename \’表名.字段名\’,\’修改字段名\’,\’COLUMN。
注意:更改对象名的任一部分都可能会破坏脚本和存储过程。

3:删除字段

1):字段存在相关约束
 语法:exec sp_helpconstraint @objname=表名(查看指定表相关约束详情)
             alter table 表名 drop constraint 约束名(删除相关约束)
             alter table 表名 drop cloumn 字段名 (删除字段)
2):无相关约束
语法:alter table 表名 drop cloumn 字段名

4:修改字段默认值

1):已存在默认值
语法:exec sp_helpconstraint @objname=表名 (查看指定表相关约束详情)
            alter table 表名 drop constraint 约束名 (删除默认值)
            alter table 表名 add default 默认值 for 字段名
2:):无默认值
语法:alter table 表名 add default 默认值 for 字段名

1.修改表名

格式:sp_rename tablename,newtablename

sp_rename tablename,newtablename

2.修改字段名

格式:sp_rename \’tablename.colname\’,newcolname,\’column\’

sp_rename \'tablename.colname\',newcolname,\'column\'

3.添加字段

格式:alter table table_name add new_column data_type [interality_codition]

示例1

ALTER TABLE student Add nationality varchar(20)

–示例2 添加int类型的列,默认值为 0

 

  1.  
    alter table student add studentName int default 0 –示例3 添加int类型的列,默认值为0,主键
  2.  
    alter table student add studentId int primary key default 0 –示例4 判断student中是否存在name字段且删除字段
  3.  
    if exists(select * from syscolumns where id=object_id(\’student\’) and name=\’name\’) begin
  4.  
    alter table student DROP COLUMN name
  5.  
    end

 

4.更改字段

格式:alter table table_name alter column column_name

 

ALTER TABLE student ALTER COLUMN name VARCHAR(200)

5.删除字段

格式:alter table table_name drop column column_name

 

ALTER TABLE student DROP COLUMN nationality;

6.查看字段约束

格式: select * from information_schema.constraint_column_usage where TABLE_NAME = table_name

 

  1.  
    SELECT TABLE_NAME,COLUMN_NAME,CONSTRAINT_NAME FROM information_schema.CONSTRAINT_COLUMN_USAGE
  2.  
    WHERE TABLE_NAME = \’student\’

7.查看字段缺省约束表达式 (即默认值等)

格式:select * from information_schema.columns where TABLE_NAME = table_name

 

  1.  
    SELECT TABLE_NAME, COLUMN_NAME, COLUMN_DEFAULT FROM information_schema.COLUMNS
  2.  
    WHERE TABLE_NAME=\’student\’

8.查看字段缺省约束名

格式:select name from sysobjects where object_id(table_name)=parent_obj and xtype=\’D\’

 

  1.  
    select name from sysobjects
  2.  
    where object_id(\’表?名?\’)=parent_obj and xtype=\’D\’

9.删除字段约束

格式:alter table tablename drop constraint constraintname

ALTER TABLE student DROP CONSTRAINT PK__student__2F36BC5B772B9A0B

10.添加字段约束

格式:alter table tablename add constraint constraintname primary key (column_name)

–示例1

  1.  
    ALTER TABLE stuInfo ADD CONSTRAINT PK_stuNo PRIMARY KEY (stuNo) –示例2 添加主键约束(Primary Key)
  2.  
     
  3.  
     
  4.  
    — 存在主键约束PK_stuNO,则删除
  5.  
    IF EXISTS(SELECT * FROM sysobjects WHERE name=\’PK_stuNo\’ and xtype=\’PK\’)
  6.  
    Alter TABLE stuInfo
  7.  
    Drop Constraint PK_stuNo
  8.  
    Go — 重新添加主键约束PK_stuNO
  9.  
    ALTER TABLE stuInfo ADD CONSTRAINT PK_stuNo PRIMARY KEY (stuNo)
  10.  
    Go –示例3 添加 唯一UQ约束(Unique Constraint)
  11.  
    — 存在唯一约束UQ_stuNO,则删除
  12.  
    IF EXISTS(SELECT * FROM sysobjects WHERE name=\’UQ_stuID\’ and xtype=\’UQ\’)
  13.  
    Alter TABLE stuInfo
  14.  
    Drop Constraint UQ_stuID
  15.  
    Go
  16.  
    — 重新添加唯一约束UQ_stuID
  17.  
    ALTER TABLE stuInfo ADD CONSTRAINT UQ_stuID UNIQUE (stuID) –示例4 添加默认DF约束(Default Constraint)
  18.  
    — 存在默认约束UQ_stuNO,则删除
  19.  
    IF EXISTS(SELECT * FROM sysobjects WHERE name=\’DF_stuAddress\’ and xtype=\’D\’)
  20.  
    Alter TABLE stuInfo Drop Constraint DF_stuAddress
  21.  
    Go — 重新添加默认约束DF_stuAddress
  22.  
    ALTER TABLE stuInfo ADD CONSTRAINT DF_stuAddress DEFAULT (\’地址不详\’) FOR stuAddress –示例5 检查CK约束(Check Constraint)
  23.  
    — 存在检查约束UQ_stuNO,则删除
  24.  
    IF EXISTS(SELECT * FROM sysobjects WHERE name=\’CK_stuAge\’ and xtype=\’C\’)
  25.  
    Alter TABLE stuInfo Drop Cons

以上所述是小编给大家介绍的SQLSERVER实现更改表名,更改列名,更改约束代码,希望对大家有所帮助!

版权声明:本文为net5x原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/net5x/articles/9591805.html