SqlServer 增加字段,修改字段名,刪除字段,修改字段默認值


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實現更改表名,更改列名,更改約束代碼,希望對大家有所幫助!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM