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

相关文章

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1