技術之路

數字創造未來

  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 :: 管理 ::

某個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 來列出其相依性。
posted on 2006-10-13 22:57  nathan  阅读(1688)  评论(0)    收藏  举报