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

ALTER TABLE table_name RENAME COLUMN old_name to new_name;

这个说法不成立。


当前回答

你还应该指定表的模式,否则你可能会得到这个错误:

Msg 15248,级别11,状态1,过程sp_rename,第238行 参数@objname不明确或者声明的@objtype (COLUMN)不明确 错了。

如果它是一个部署脚本,我还建议添加一些额外的安全性。

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'
    )
    EXEC sp_RENAME 'SchemaName.TableName.OldColumnName', 'NewColumnName', 'COLUMN';

其他回答

这将是一个很好的建议,使用一个已经内置的函数,但另一种方法是:

创建一个具有相同数据类型和new NAME的新列。 运行UPDATE/INSERT语句将所有数据复制到新列中。 删除旧的列。

使用sp_rename的好处是它处理了与它相关的所有关系。

从文档中可以看到:

每当重命名PRIMARY KEY或UNIQUE约束时,sp_rename会自动重命名关联的索引。如果重命名的索引绑定到PRIMARY KEY约束,那么PRIMARY KEY约束也会通过sp_rename自动重命名。sp_rename可用于重命名主要和次要XML索引。

运行查询:

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

除了SQL之外,您还可以在Microsoft SQL Server Management Studio中执行此操作。下面是一些使用GUI的快速方法:

第一个方法

缓慢双击列。列名将成为一个可编辑的文本框。


第二种方式

右键单击列并从上下文菜单中选择“重命名”。

例如:


第三条道路

当您需要一次性重命名多个列时,这种方式更可取。

右键单击包含需要重命名的列的表。 点击设计。 在表设计面板中,单击并编辑要更改的列名的文本框。

例如:

注意:我知道OP特别要求SQL解决方案,认为这可能有助于其他人:)

@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

Try:

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