我使用SQL Server 2008和Navicat。我需要使用SQL重命名表中的列。

ALTER TABLE table_name RENAME COLUMN old_name to new_name;

这个说法不成立。


当前回答

因为我经常来这里,然后想知道如何使用括号,这个答案可能对像我这样的人有用。

EXEC sp_rename '[DB].[dbo].[Tablename].OldColumnName', 'NewColumnName', 'COLUMN'; 

OldColumnName不能在[]中。这是行不通的。 不要在[]中输入NewColumnName,它会生成[[NewColumnName]]。

其他回答

Try:

EXEC sp_rename 'TableName.OldName', 'NewName', 'COLUMN'

Sql Server管理工作室有一些系统定义的存储过程(SP) 其中一个用于重命名列。SP为sp_rename

语法:sp_rename '[table_name]。old_column_name”、“new_column_name” 如需进一步帮助,请参阅本文:sp_rename by Microsoft Docs

注意:在执行此SP时,sql server会给你一个警告消息,如“警告:更改对象名称的任何部分都可能破坏脚本和存储过程”。只有当您编写了自己的sp,其中涉及您要更改的表中的列时,这才至关重要。

运行查询:

    SP_RENAME '[TableName].[ColumnName]','NewNameForColumn'

或者你可以在SQL Management Studio中慢点两次列并通过UI重命名它…

@Taher的改进版本

DECLARE @SchemaName AS VARCHAR(128)
DECLARE @TableName AS VARCHAR(128)
DECLARE @OldColumnName AS VARCHAR(128)
DECLARE @NewColumnName AS VARCHAR(128)
DECLARE @ParamValue AS VARCHAR(1000)

SET @SchemaName = 'dbo'
SET @TableName = 'tableName'
SET @OldColumnName = 'OldColumnName'
SET @NewColumnName = 'NewColumnName'
SET @ParamValue = @SchemaName + '.' + @TableName + '.' + @OldColumnName

IF EXISTS
(
    SELECT 1 FROM sys.columns WHERE name = @OldColumnName AND OBJECT_NAME(object_id) = @TableName
)
AND NOT EXISTS
(
    SELECT 1 FROM sys.columns WHERE name = @NewColumnName AND OBJECT_NAME(object_id) = @TableName
)
BEGIN
    EXEC sp_rename @ParamValue, @NewColumnName, 'COLUMN';
END