C#读取Mysql blob字段 (转帖)

http://blog.csdn.net/config_man/article/details/6123191

开发环境:Windows XP Professional SP3、VS2008、Winform、MySQL5.0、MySQL.Data.dll 6.2.3.0

1、从硬盘上读取一图片,将其转化为流,然后存储到此BLOB字段中

[csharp] view plaincopyprint?

  1. private void button1_Click(object sender, EventArgs e)
  2. {
  3. byte[] bytes = null;
  4. bytes = File.ReadAllBytes(@"C:/Documents and Settings/user/My Documents/My Pictures/11.jpg");
  5. using (MySql.Data.MySqlClient.MySqlConnection conn = new MySql.Data.MySqlClient.MySqlConnection())
  6. {
  7. conn.ConnectionString = ConfigurationManager.ConnectionStrings["test"].ConnectionString;
  8. MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand();
  9. cmd.CommandText = "insert into test(id,picture) values(@id,@picture)";
  10. cmd.CommandType = CommandType.Text;
  11. cmd.Parameters.Add("@id", MySql.Data.MySqlClient.MySqlDbType.Int32);
  12. cmd.Parameters.Add("@picture", MySql.Data.MySqlClient.MySqlDbType.Blob);
  13. cmd.Parameters[0].Value = 15;
  14. cmd.Parameters[1].Value = bytes;
  15. cmd.Connection = conn;
  16. conn.Open();
  17. int affectedrows = cmd.ExecuteNonQuery();
  18. cmd.Dispose();//此处可以不用调用,
  19. conn.Close();// 离开 using 块, connection 会自行关闭
  20. }
  21. }
 

2、读取此BLOB字段,将其转化为图片显示在Picturebox控件上

[csharp] view plaincopyprint?

  1. private void button2_Click(object sender, EventArgs e)
  2. {
  3. using (MySql.Data.MySqlClient.MySqlConnection conn = new MySql.Data.MySqlClient.MySqlConnection())
  4. {
  5. conn.ConnectionString = ConfigurationManager.ConnectionStrings["test"].ConnectionString;
  6. conn.Open();
  7. MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand();
  8. cmd.CommandType = CommandType.Text;
  9. cmd.CommandText = "select id,picture from test where id = 11";
  10. cmd.Connection = conn;
  11. System.Data.Common.DbDataReader reader = cmd.ExecuteReader();
  12. byte[] buffer = null;
  13. if (reader.HasRows)
  14. {
  15. reader.Read();
  16. long len = reader.GetBytes(1, 0, null, 0, 0);//1是picture
  17. buffer = new byte[len];
  18. len = reader.GetBytes(1, 0, buffer, 0, (int)len);
  19. System.IO.MemoryStream ms = new System.IO.MemoryStream(buffer);
  20. System.Drawing.Image iamge = System.Drawing.Image.FromStream(ms);
  21. pictureBox1.Image = iamge;
  22. }
  23. }
  24. }
 

数据库相关文件配置在App.config中,如果不用配置文件,可以写成:

string remote = "Persist Security Info=False;database=数据库名;server=服务器IP;user id=用户名;pwd=密码";

然后conn.ConnectionString = remote;即可。

后记:

之前在.net中用的mysql库是:MySQLDriverCS,但是一直没有搞定,而且用官方给的读取blob字段也失败。于是改用MySql.Data.dll ,注意Mysql.Data5.0版本不支持读取Blob字段,所以需要用较高版本,我用的是MySQL.Data.dll 6.2.3.0。

MySql.Data.dll 6.2.3.0下载地址:http://download.csdn.net/source/2968152

MySql.Data.dll 5.0.9.0下载地址:http://download.csdn.net/source/2968157

时间: 2024-08-25 06:57:31

C#读取Mysql blob字段 (转帖)的相关文章

MYSQL BLOB 字段大小以及个数的限制测试。

测试结论 mysql版本 5.1 表类型: innodb, row_format=compact (这是默认的行格式) 插入超过10个blob, blob的数据量很小(<768字节), 插入成功. 插入超过10个blob, blob的数据量很大(>768字节), 插入失败:报 Got error 139 from storage engine. 注意,如果mysql服务器版本是5.1, innodb_file_format选项不存在, 也就无从谈起Barracuda格式. 设置row_form

MYSQL BLOB 字段大小以及个数的限制測试。

測试结论mysql版本号 5.1    表类型: innodb, row_format=compact (这是默认的行格式)    插入超过10个blob, blob的数据量非常小(<768字节), 插入成功.    插入超过10个blob, blob的数据量非常大(>768字节), 插入失败:报 Got error 139 from storage engine.     注意,假设mysqlserver版本号是5.1, innodb_file_format选项不存在, 也就无从谈起Barr

SpringMVC处理MYSQL BLOB字段的上传

任务: uos.docfile的content字段是longblob类型的,通过页面将文件存储到这个字段里. 页面代码: <div class="box"> <div class="box-head"> <h2>Upload a document</h2> </div> <form name="form1" action="uploadDocument.html"

mysql BLOB字段转String的方法

1.通过sql直接转换 select CONVERT(GROUP_CONCAT(XXX) USING utf8 from usertable; 2.通过程序转换(注:本例用的是springmvc包装并返回结果集) String srt2;   try {         srt2 = new String((byte[])entry.getValue(),"UTF-8");          hashmap.put(entry.getKey().toString(), srt2); 

java 读写Oracle Blob字段

许久没有分享代码了,把这段时间写的一个Java操作Blob字段,有日子没写Java了,就当作笔记记录一下.1. [代码][Java]代码     跳至 [1] [全屏预览]package com.wanmei.meishu;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.FileReader;import java.io.InputStream;import java.io.OutputS

wpf读取mysql字段类型为text的问题

在读取数据库中的字段时,可能会根据环境的不同导致一些字段的读取方式不尽相同,在sql数据库中读取字段值用的最多的算是dataTable.Rows[行][列],但是到了mysql中就会有一些差别,在flex中可以按照这种方式进行读取,但是到了wpf中读取mysql中的text字段就会有差别,有幸让我碰到了这个问题,当时也是一头雾水,反复检查了数据库中的编码格式及代码块:确定几遍,格式是设定好的格式,代码是熟悉的代码,但是为什么按照常规的方式读取获取到的是byte类型的值呢? --百思不得其解,最后

mysql怎么储存长字符-----MySQL text与blob字段类型的不同之处

字段类型选text型 或blog 区别见: 以下的文章主要介绍的是MySQL text与blob字段类型的不同之处的比较,同时本文也有对MySQL text与blob字段类型的实际应用的介绍,如果你对MySQL text与blob字段类型相关的实际操作有兴趣的话,你就可以对以下的文章点击观看了. 1. blob是二进制大对象,可以容纳可变量数量的数据,其中blob分为4中类型:TINYBLOB,BLOB,mediumblob和LongBlob,他们容纳的长度是不同的. Text同样也分为四种类型

Java读取/更新Oracle数据库blob字段

在写java程序过程中,如何读取Oracle数据库表某类型为blob的字段? 以下是我在写程序的时候一种解决方法.核心语句.(传上来做了修改,格式不要学习,养成良好习惯) 详细请参考: 读取序列ID:http://blog.csdn.net/yzsind/article/details/6918506 BLOB相关:http://jslfl.iteye.com/blog/1771949 http://www.linuxidc.com/Linux/2011-08/40218.htm http://

Navicat for MySQL 查看BLOB字段内容

Navicat for MySQL 查看BLOB字段内容查看BLOB内容的两种方法: 1. 在查询窗口中选中BLOB字段,点击备注 2.  查看->原始数据模式