微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql-server-2005 – 在SQL Server中重命名列的问题

所以我试图将我的表格中的列从Conversion_Fee_PerShare重命名为转换费用.

我在网上查了一下,发现语法是:

sp_RENAME 'TableName.[OldColumnName]','[NewColumnName]','COLUMN'

我把我的查询写成:

sp_RENAME 'dbo.AllocationDetails.[Conversion_Fee_Per_Share]','[Conversion_Fee]','COLUMN'

列名现在变为[Conversion_Fee]而不是Conversion_Fee

现在如果我想再次重命名,就像这样:

sp_RENAME 'dbo.AllocationDetails.[Conversion_Fee]','Conversion_Fee','COLUMN'

它给我一个错误说:

Msg 15248,Level 11,State 1,
Procedure sp_rename,Line 213 Either
the parameter @objname is ambiguous or
the claimed @objtype (COLUMN) is
wrong.

我试图改变表删除列AllocationDetails.[Conversion_Fee]它也没有那样工作.

什么是正确的语法?

解决方法

/*Initial Table*/  
CREATE TABLE AllocationDetails
  (
     Conversion_Fee_Per_Share FLOAT
  )

/*Faulty Rename*/  
EXEC sp_rename
  'dbo.AllocationDetails.[Conversion_Fee_Per_Share]','COLUMN'

/*Fixed Rename*/  
EXEC sp_rename
  'dbo.AllocationDetails.[[Conversion_Fee]]]','COLUMN'

DROP TABLE AllocationDetails

在第二个sp_rename调用中使用的列名是SELECT QUOTENAME(‘[Conversion_Fee_Per_Share]’)返回的.

或者更直接地可以使用

EXEC sp_rename
  'dbo.AllocationDetails."[Conversion_Fee]"','COLUMN'

对于该存储过程,QUOTED_IDENTIFIER始终设置为on,因此这不依赖于您在会话设置中启用此功能.

原文地址:https://www.jb51.cc/mssql/83394.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐