在SQL Server中将数据类型Varchar更改为Varbinary(max)

时间:2013-06-16 16:03:23

标签: sql sql-server

我想使用此查询在SQL Server中将varchar更改为varbinary(max)

ALTER TABLE  [dbo].[Attachments]
ALTER COLUMN [Content]  varbinary(max)  NOT NULL

但是会引发以下异常:

  

不允许从数据类型varchar到varbinary(max)的隐式转换。使用CONVERT函数运行此查询

在这种情况下我应该改变什么?

3 个答案:

答案 0 :(得分:6)

您确定要varbinary(max)吗?如果是这样,我相信您需要分步执行此操作:

ALTER TABLE Attachments
ADD Content2 varbinary(max)

UPDATE Attachments
SET Content2 = CONVERT(varbinary(MAX),Content)

ALTER TABLE Attachments
DROP COLUMN Content

sp_RENAME 'Attachments.[Content2]' , '[Content]', 'COLUMN'

根据表格的性质,通过选择转换为:

可能会更快
SELECT Content = CAST(Content AS VARBINARY(MAX))
       ,other fields
INTO NewTable
FROM OldTable

然后删除旧表并重命名新表:

DROP TABLE OldTable
GO
SP_RENAME 'NewTable', 'OldTable'

答案 1 :(得分:5)

您需要暂存流程:

    ALTER TABLE  [dbo].[Attachments]
    ADD [TempContent]  varbinary(max) 

go

    UPDATE Attachements SET TempContent = CAST(Content as VARBINARY)
go 

    ALTER TABLE  [dbo].[Attachments]
    DROP COLUMN [Content] 

go  
    sp_RENAME 'Attachements.[TempContent ]' , '[Content ]', 'COLUMN'

go

您也可以在SQL Server Management Studio中执行此操作,如果启动分析器,它将显示它使用的代码(总是有帮助的)

答案 2 :(得分:0)

将文件插入数据库时​​使用此方法:

SqlCommand cmd = new SqlCommand("Insert into tblJobSeeker Values('"+txtUserName.Text+"',@Data)",con);
cmd.Parameters.AddWithValue("@Data",Filesize);