如何在T-SQL中更改SQL Server列名?

时间:2010-05-27 14:37:13

标签: sql sql-server tsql

我有一个从CSV文件导入600多列的表,列名中有特殊字符% _ -。 有没有办法更改列名以删除这些特殊字符?

代码可以在T-SQL中。

4 个答案:

答案 0 :(得分:9)

sp_rename

EXEC sp_rename 'table.[Oh%Dear]', 'OhDear', 'COLUMN';

工作示例(不确定sp_rename中的[ ]

CREATE TABLE foo ([Oh%Dear] int)

EXEC sp_rename 'foo.[Oh%Dear]', 'OhDear', 'COLUMN'

EXEC sys.sp_help 'foo'

答案 1 :(得分:8)

您可以查询INFORMATION_SCHEMA.COLUMNS并生成sp_rename脚本以重命名列。

SELECT 'EXEC sp_rename ''' + TABLE_NAME + '.' + QUOTENAME(COLUMN_NAME) + ''', ''' + REPLACE(COLUMN_NAME, '%', '') + ''', ''COLUMN''; '
FROM INFORMATION_SCHEMA.COLUMNS
WHERE COLUMN_NAME LIKE '%[%]%'

这是a permalink to an actual runnable example

答案 2 :(得分:5)

你能用这个吗?

sp_RENAME 'Table.ColumnName%', 'NewColumnName' , 'COLUMN'

答案 3 :(得分:3)

这是一个循环表并更改下划线和百分号

的示例
create table Test ([col%1] varchar(50),[col_2] varchar(40))
go

select identity(int,1,1) as id ,column_name,table_name into #loop
 from information_schema.columns
where table_name = 'Test'
and column_name like '%[%]%'
or column_name like '%[_]%'


declare @maxID int, @loopid int
select @loopid =1
select @maxID = max(id) from #loop

declare  @columnName varchar(100), @tableName varchar(100)
declare  @TableColumnNAme varchar(100)
while @loopid <= @maxID
begin


select @tableName = table_name , @columnName = column_name
from #loop where id = @loopid

select @TableColumnNAme = @tableName + '.' + @columnName
select @columnName = replace(replace(@columnName,'%',''),'_','')
EXEC sp_rename @TableColumnNAme, @columnName, 'COLUMN';

set @loopid = @loopid + 1
end

drop table #loop

select * from Test