sql實現(xiàn)修改表字段名的方法詳解
sp_rename N'表名.字段名','新字段名','column'
sp_rename
更改當前數(shù)據(jù)庫中用戶創(chuàng)建對象(如表、列或用戶定義數(shù)據(jù)類型)的名稱。
語法
sp_rename [ @objname = ] 'object_name' ,
[ @newname = ] 'new_name'
[ , [ @objtype = ] 'object_type' ]
參數(shù)
[@objname =] 'object_name'
是用戶對象(表、視圖、列、存儲過程、觸發(fā)器、默認值、數(shù)據(jù)庫、對象或規(guī)則)或數(shù)據(jù)類型的當前名稱。如果要重命名的對象是表中的一列,那么 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ù)據(jù)庫。要重命名數(shù)據(jù)庫時需用此選項。
INDEX 用戶定義的索引。
OBJECT 在 sysobjects 中跟蹤的類型的項目。例如,OBJECT 可用來重命名約束(CHECK、FOREIGN KEY、PRIMARY/UNIQUE KEY)、用戶表、視圖、存儲過程、觸發(fā)器和規(guī)則等對象。
USERDATATYPE 通過執(zhí)行 sp_addtype 而添加的用戶定義數(shù)據(jù)類型。
返回代碼值
0(成功)或非零數(shù)字(失?。?br>
注釋
只能更改當前數(shù)據(jù)庫中的對象名稱或數(shù)據(jù)類型名稱。大多數(shù)系統(tǒng)數(shù)據(jù)類型和系統(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ù)據(jù)庫角色成員或?qū)ο笏姓呖梢詧?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ù) REGEXP_REPLACE的使用方法小結
假設您的數(shù)據(jù)在正文中有不必要的空格,您希望用單個空格來替換它們,利用REPLACE函數(shù) ,這篇文章給大家介紹sql函數(shù) REGEXP_REPLACE的使用方法小結,感興趣的朋友一起看看吧2023-11-11sql中時間以5分鐘半個小時任意間隔分組的實現(xiàn)方法
這篇文章主要介紹了sql中時間以5分鐘半個小時任意間隔分組的實現(xiàn)方法,在文中給大家提到了sql server時間查詢的代碼,需要的朋友可以參考下2019-06-06揭秘SQL Server 2014有哪些新特性(3)-可更新列存儲聚集索引
可更新的列存儲索引作為SQL Server 2014的一個關鍵功能之一,在提升數(shù)據(jù)庫的查詢性能方面貢獻非常突出。據(jù)微軟統(tǒng)計,在面向OLAP查詢統(tǒng)計類系統(tǒng)中,相比其他SQL傳統(tǒng)版本的數(shù)據(jù)庫,報表查詢的性能最大可提升上十倍。2014-08-08linux下apache、mysql、php安裝配置詳細筆記
linux下apache、mysql、php安裝配置筆記,有需要的朋友可以參考下2013-02-02一個完整的SQL SERVER數(shù)據(jù)庫全文索引的示例介紹
以下是介紹SQL SERVER數(shù)據(jù)庫全文索引的示例,以pubs數(shù)據(jù)庫為例。需要的朋友參考下2013-07-07創(chuàng)建動態(tài)MSSQL數(shù)據(jù)庫表
下面是利用SQL語句創(chuàng)建數(shù)據(jù)庫、表、存儲過程、視圖、索引、規(guī)則、修改表、查看數(shù)據(jù)等的方法。2009-06-06