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