【发布时间】:2019-01-18 15:51:36
【问题描述】:
我正在尝试将图像转换为字节数组以将其上传到 SQL 数据库,项目成功构建,但在使用实体框架中的代码优先方法更新数据库时,我得到了找不到文件的异常,但是文件在 app_data 中。
public override void Up()
{
Sql("SET IDENTITY_INSERT Movies ON");
Image image = Image.FromFile(@"c:\users\erprakash\source\DeltaXIMDB\DeltaXIMDB\App_Data\om.png");
byte[] byteimage = imageToByteArray(image);
Sql($"INSERT INTO Movies(Id,Name,YearOfRelease,Plot,Image) VALUES(1,'Mission Impossible Fallout','2018',{byteimage}");
Sql("SET IDENTITY_INSERT Movies OFF");
}
如果有任何建议和解决方案,请分享。 谢谢
【问题讨论】:
-
请注意:图像在磁盘上已经是二进制的,为什么将其加载为图像并转换为二进制?只加载文件?至于报错,权限设置是否正确?
-
关于您的 sql:请注意,使用通常的种子值,IDENTITY_INSERT 不会实现任何目的。另请注意,您尝试插入的值缺少 Plot 参数。
标签: c# entity-framework code-first filenotfoundexception