sql读写图片时Image.FromStream方法提示参数错误问题解决

本文主要是介绍sql读写图片时Image.FromStream方法提示参数错误问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们通常这么写

using (SqlDataReader drm = sqlComm.ExecuteReader()){drm.Read();//以下把数据库中读出的Image流在图片框中显示出来.MemoryStream ms = new MemoryStream((byte[])drm["Logo"]);Image img = Image.FromStream(ms);this.pictureBox1.Image = img;}


 

 

我的写数据

        private void btnOK_Click(object sender, EventArgs e){string name = "";if (tbxUserName.Text.Trim() == ""){MessageBox.Show("姓名不能为空,请重新输入!", "提示");return;}else{name = tbxUserName.Text.Trim();}string group = "";if (cbxGroup.Text.Trim() == ""){group = "未分组";}else{group = cbxGroup.Text.Trim();}string phone = tbxTel.Text.Trim();string workunit = tbxWorkUnit.Text.Trim();string email = tbxEmail.Text.Trim();string qq = tbxQQ.Text.Trim();byte[] b = null;if (txtFilePath != ""){try{FileStream fs = new FileStream(txtFilePath, FileMode.Open, FileAccess.Read);//类型为打开数据 权限为只读 不呢写数据int length = Convert.ToInt32(fs.Length);b = new byte[length];fs.Read(b, 0, length);//数据读入b数组中 从0号到length位fs.Close();//关闭输入输出流}catch (Exception ex){b = null;MessageBox.Show(ex.Message);}}else {b = pixData;}try{using (SqlConnection connection = new SqlConnection(connectionString)){//获取当前的数据在表中的IDSqlCommand commandInsert = new SqlCommand();commandInsert.Connection = connection;//connection.Close();connection.Open();//插入数据commandInsert.CommandText = "USE db_TXL UPDATE tb_BusicInfo set Groups= @Groups ,Name=@Name,WorkUnit=@WorkUnit,Phone=@Phone,Email=@Email,QQ=@QQ,Picture=@Picture";commandInsert.CommandText += "  where ID=@ID ";commandInsert.Parameters.Add("@ID", SqlDbType.Int);commandInsert.Parameters.Add("@Groups", SqlDbType.VarChar, 50);commandInsert.Parameters.Add("@Name", SqlDbType.VarChar, 20);commandInsert.Parameters.Add("@WorkUnit", SqlDbType.VarChar, 50);commandInsert.Parameters.Add("@Phone", SqlDbType.VarChar, 14);commandInsert.Parameters.Add("@Email", SqlDbType.VarChar, 50);commandInsert.Parameters.Add("@QQ", SqlDbType.VarChar, 20);commandInsert.Parameters.Add("@Picture", SqlDbType.Image);//Image的类型不能写错!!commandInsert.Parameters["@ID"].Value = ID;//  commandInsert.Parameters["@UserName"].Value = strUserName;commandInsert.Parameters["@Groups"].Value = group;commandInsert.Parameters["@Name"].Value = name;commandInsert.Parameters["@WorkUnit"].Value = workunit;commandInsert.Parameters["@Phone"].Value = phone;commandInsert.Parameters["@Email"].Value = email;commandInsert.Parameters["@QQ"].Value = qq;//commandInsert.Parameters[""].Value=;if (txtFilePath == "" && pixData==null){commandInsert.Parameters["@Picture"].Value = DBNull.Value;//DBNull  不存在的值NULL}else{commandInsert.Parameters["@Picture"].Value = b;}commandInsert.ExecuteNonQuery();connection.Close();DialogResult = DialogResult.OK;}}catch (Exception ex) { MessageBox.Show(ex.Message); }}


 

我的读数据

     private void frmEdit_Load(object sender, EventArgs e){try{using (SqlConnection connection = new SqlConnection(connectionString)){string commandString = "select * from tb_BusicInfo where ID= " + ID.ToString() + " ";SqlCommand command = new SqlCommand(commandString, connection);connection.Open();SqlDataReader reader = command.ExecuteReader();if (reader.Read()){tbxUserName.Text = Convert.ToString(reader["Name"]);cbxGroup.Text = Convert.ToString(reader["Groups"]);tbxTel.Text = Convert.ToString(reader["Phone"]);tbxWorkUnit.Text = Convert.ToString(reader["WorkUnit"]);tbxEmail.Text = Convert.ToString(reader["Email"]);tbxQQ.Text = Convert.ToString(reader["QQ"]);if (reader["Picture"] == DBNull.Value){pbxPicture.Image = TongXunLu.Properties.Resources.defaultPix;}else{// string a=reader["Picture"].ToString();//  byte[] b = (byte[])((reader["Picture"]));MemoryStream buf = new MemoryStream((byte[])reader["Picture"]);Image image = Image.FromStream(buf);Bitmap bt = new Bitmap(image);pbxPicture.Image = bt;//pbxPicture.Image = image;//  pbxPicture.Image = Image.FromStream(new MemoryStream(b));//把二进制流读出来??问题}}reader.Close();connection.Close();}}catch (Exception ex){MessageBox.Show(ex.Message);}}


 

读数据的时候,但是在写数据的时候可能发生了一些错误。

果然我在追寻byte[]的数组的时候发现 写的时候有2万多个 读的时候只有50个

于是我想可能是写的时候出了问题,于是

 

commandInsert.Parameters.Add("@Picture", SqlDbType.Image,50);

改为commandInsert.Parameters.Add("@Picture", SqlDbType.Image);

照片可以正常显示了

参考了http://blog.csdn.net/zystory/article/details/4399338

你存数据的时候出了问题,和读数据没有关系
new SqlParameter("@L_RolePic", SqlDbType.Image, 16) 改为 new SqlParameter("@L_RolePic", SqlDbType.Image),

这篇关于sql读写图片时Image.FromStream方法提示参数错误问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/988302

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1