我想使用此查询在SQL Server中将varchar
更改为varbinary(max)
:
ALTER TABLE [dbo].[Attachments]
ALTER COLUMN [Content] varbinary(max) NOT NULL
但是会引发以下异常:
不允许从数据类型varchar到varbinary(max)的隐式转换。使用CONVERT函数运行此查询
在这种情况下我应该改变什么?
答案 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);