c# - 从 nvarchar 转换为 varbinary(max)
问题描述
我目前正在通过按钮单击功能为表格中的记录生成二维码图像,然后需要将生成的图像保存到表格中。
但我只能生成二维码图像,我似乎无法将图像存储到数据库中。给我的错误是:
不允许从数据类型 nvarchar 到 varbinary(max) 的隐式转换。使用 CONVERT 函数运行此查询。
我在网上搜索了各种方法,但我似乎无法理解 CONVERT 函数的实际工作原理。下面是我的代码:
string toinsertcode = "Consignment Number: " + txtConsignmentNum.Text +
"\n" + "Student ID: " + txtStudentID.Text;
QRCodeGenerator qrGenerator = new QRCodeGenerator();
QRCodeGenerator.QRCode qrCode = qrGenerator.CreateQrCode(toinsertcode, QRCodeGenerator.ECCLevel.Q);
System.Web.UI.WebControls.Image imgQRCode = new System.Web.UI.WebControls.Image();
imgQRCode.Height = 150;
imgQRCode.Width = 150;
using (Bitmap bitmap = qrCode.GetGraphic(80))
{
using (MemoryStream ms = new MemoryStream())
{
bitmap.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
byte[] byteImage = ms.ToArray();
imgQRCode.ImageUrl = "data:image/png;base64, " + Convert.ToBase64String(byteImage);
}
placeholderQR.Controls.Add(imgQRCode);
}
conn.Open();
string insertqrcode = "INSERT INTO Parcel(QRCode) values(@qr)";
SqlCommand cmdupload = new SqlCommand(insertqrcode, conn);
cmdupload.Parameters.AddWithValue("@qr", imgQRCode);
cmdupload.ExecuteNonQuery();
conn.Close();
解决方案
您需要实际发送字节,而不是将对象作为某种字符串发送到数据库。
此外,使用显式数据类型定义参数也是一个好主意,以避免 C# 猜测(错误地)您所需的数据类型,就像它在此处对您所做的那样。
代替:
cmdupload.Parameters.AddWithValue("@qr", imgQRCode);
和:
cmdupload.Parameters.Add("@qr", SqlDbType.VarBinary, -1 ).Value = byteImage;
显然,您还需要将数据库插入语句移动到定义您的范围byteImage
以使其工作。
推荐阅读
- jquery - Jquery Mapael:如何使用 HTML 表格数据来替换这个硬编码示例?
- c# - 在直接调用委托的情况下如何减轻“访问修改的闭包”
- python-imaging-library - 打开的文件太多
- xcode - 如何在启动 Mac os 时自动加载 kext?
- vba - 在使用 wdDialogFileOpen 打开文件之前,有什么方法可以检查文件的类型吗?
- css - 在这种情况下,有没有更好的方法来使用嵌套的 SASS 和选择器?
- regex - 在空条目上获取 ArgumentNullException
- appveyor - 如何在appveyor上调用boost库,如何设置环境变量以成功运行boost测试?
- php - 如何在 PHP 数组中返回不同的和最新的值
- javascript - 如何从对象数组中检查对象中值的长度