sp_rename N'表名.字段名','新字段名','column'
sp_rename
更改當前數(shù)據庫中用戶創(chuàng)建對象(如表、列或用戶定義數(shù)據類型)的名稱。
語法
sp_rename [ @objname = ] 'object_name' ,
[ @newname = ] 'new_name'
[ , [ @objtype = ] 'object_type' ]
參數(shù)
[@objname =] 'object_name'
是用戶對象(表、視圖、列、存儲過程、觸發(fā)器、默認值、數(shù)據庫、對象或規(guī)則)或數(shù)據類型的當前名稱。如果要重命名的對象是表中的一列,那么 object_name 必須為 table.column 形式。如果要重命名的是索引,那么 object_name 必須為 table.index 形式。object_name 為 nvarchar(776) 類型,無默認值。
[@newname =] 'new_name'
是指定對象的新名稱。new_name 必須是名稱的一部分,并且要遵循標識符的規(guī)則。newname 是 sysname 類型,無默認值。
[@objtype =] 'object_type'
是要重命名的對象的類型。object_type 為 varchar(13) 類型,其默認值為 NULL,可取下列值。
值描述
COLUMN 要重命名的列。
DATABASE 用戶定義的數(shù)據庫。要重命名數(shù)據庫時需用此選項。
INDEX 用戶定義的索引。
OBJECT 在 sysobjects 中跟蹤的類型的項目。例如,OBJECT 可用來重命名約束(CHECK、FOREIGN KEY、PRIMARY/UNIQUE KEY)、用戶表、視圖、存儲過程、觸發(fā)器和規(guī)則等對象。
USERDATATYPE 通過執(zhí)行 sp_addtype 而添加的用戶定義數(shù)據類型。
返回代碼值
0(成功)或非零數(shù)字(失?。?br>
注釋
只能更改當前數(shù)據庫中的對象名稱或數(shù)據類型名稱。大多數(shù)系統(tǒng)數(shù)據類型和系統(tǒng)對象的名稱不能更改。
重命名視圖時,sysobjects 表中有關該視圖的信息將得到更新。重命名存儲過程時,sysobjects 表中有關該過程的信息將得到更新。
每當重命名 PRIMARY KEY 或 UNIQUE 約束時,sp_rename 都會自動為相關聯(lián)的索引重命名。如果重命名的索引與 PRIMARY KEY 約束相關聯(lián),那么 sp_rename 也會自動重命名主鍵。
重要 重命名存儲過程和視圖后,請清空過程高速緩存以確保所有相關的存儲過程和視圖都重新編譯。
重命名存儲過程、視圖或觸發(fā)器不會更改 syscomments 表中相應對象的名稱。由于原來的名稱將從 syscomments 表插入 CREATE 語句,因此這樣可能會導致為該對象生成腳本時出現(xiàn)問題。要獲得最佳結果,請不要重命名這些對象類型,而應該刪除并用新名稱重新創(chuàng)建對象。
權限
sysadmin 固定服務器角色成員、db_owner 和 db_ddladmin 固定數(shù)據庫角色成員或對象所有者可以執(zhí)行 sp_rename。只有 sysadmin 和 dbcreator 固定服務器角色成員才能將"database"作為 object_type 來執(zhí)行 sp_rename。
示例
A. 重命名表
下例將表 customers 重命名為 custs。
EXEC sp_rename 'customers', 'custs'
B. 重命名列
下例將表 customers 中的列 contact title 重命名為 title。
EXEC sp_rename 'customers.[contact title]', 'title', 'COLUMN'
重命名列:下例將表 customers 中的列 contact title 重命名為 title。
EXEC sp_rename 'customers.[contact title]', 'title', 'COLUMN'
您可能感興趣的文章:- sql 批量修改數(shù)據庫表
- Sql中存儲過程的定義、修改和刪除操作
- 一條SQL語句修改多表多字段的信息的具體實現(xiàn)
- 使用SQL批量替換語句修改、增加、刪除字段內容
- SQL修改語法語句梳理總結