某個table內的某一個欄位的型態要如何使用語法完成呢

比方說

A1 varchar(10)  ---->  A1 varchar(20)

A2 tinyint   ----->   B2 int

第一個只改變欄位的長度或是型態

第二個改變名稱或是改變名稱與型態

做法如下:
由於您並未說明 SQL Server 的版本為何,以下說明,以 SQL Server 2005 為主

關於第一個問題,可以使用 ALTER TABLE 陳述式:

 


CREATE TABLE 我的資料表 (欄位A varchar(10));
GO
ALTER TABLE 我的資料表 ALTER COLUMN 欄位A nvarchar(25) NOT NULL;
GO
ALTER TABLE 我的資料表 ALTER COLUMN 欄位A varchar(50) NULL;
GO

第二個問題,若僅是更改欄位名稱,請使用 sp_rename 這個預存程序,如下所示即是一例:

EXEC sp_rename '我的資料表.欄位A', '卓立民', 'COLUMN';
GO

若要更改欄位名稱與型態,就需要分成兩道指令來進行,比方說:先使用一道指令來更改欄位名稱,然後再使用第二道指令來更改欄位型態,如下所示即是一例:

EXEC sp_rename '我的資料表.卓立民', '姓名', 'COLUMN';
ALTER TABLE 我的資料表 ALTER COLUMN 姓名 nvarchar(50) NULL;
GO

最後,要記得刪除這個資料表:

DROP TABLE 我的資料表;
GO

請注意:

  1. 當您所欲更改欄位長度或資料型別的資料表有條件約束時,SQL Server 並不會自動幫您修改這些條件約束,此時,請先移除條件約束,待更改欄位長度或資料型別之後,再建立這些條件約束,以免於執行操作時,發生錯誤訊息。
  2. 重新命名欄位的物件,不會自動重新命名與這個物件相關的參考物件名稱。您必須手動修改任何參考重新命名之物件的物件。比方說,您重新命名某一個欄位,且有觸發程序參考這個欄位,您必須修改觸發程序來反映新的欄位名稱。在重新命名欄位之前,您可以使用 sys.sql_dependencies 來列出其相依性。

相关文章:

  • 2021-05-23
  • 2022-01-08
  • 2021-10-13
  • 2021-08-09
  • 2022-12-23
  • 2022-02-27
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-01-04
  • 2022-12-23
  • 2022-12-23
  • 2021-12-27
相关资源
相似解决方案