最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

C#实现MySQL数据库中的blob数据存储_MySQL

来源:懂视网 责编:小采 时间:2020-11-09 20:09:50
文档

C#实现MySQL数据库中的blob数据存储_MySQL

C#实现MySQL数据库中的blob数据存储_MySQL:在MySQL数据库中,有一种blob数据类型,用来存储文件。C#编程语言操作MySQL数据库需要使用MySQL官方组件MySQL.Data.dll。 Mysql.Data.dll(6.9.6)组件下载地址:http://download.csdn.net/detail/keypig_zz/9262767。
推荐度:
导读C#实现MySQL数据库中的blob数据存储_MySQL:在MySQL数据库中,有一种blob数据类型,用来存储文件。C#编程语言操作MySQL数据库需要使用MySQL官方组件MySQL.Data.dll。 Mysql.Data.dll(6.9.6)组件下载地址:http://download.csdn.net/detail/keypig_zz/9262767。
在MySQL数据库中,有一种blob数据类型,用来存储文件。C#编程语言操作MySQL数据库需要使用MySQL官方组件MySQL.Data.dll。

Mysql.Data.dll(6.9.6)组件下载地址:http://download.csdn.net/detail/keypig_zz/9262767。

现在说一说如何实现blob类型数据的操作。

新建winform程序,添加两个按钮。代码如下:

 1 System.IO.MemoryStream ms = new System.IO.MemoryStream();
 2 private void button1_Click(object sender, EventArgs e)
 3 {
 4 //测试序列化与反序列化
 5 int[] arr = { 1, 2, 3 };
 6 BinaryFormatter bFormatter = new BinaryFormatter();
 7 bFormatter.Serialize(ms, arr);
 8 byte[] byteArr = ms.ToArray();
 9 MessageBox.Show(byteArr.Length.ToString());
10 MySqlConnection conn = new MySqlConnection(Properties.Settings.Default.MySqlConnectString);
11 //string insertStr = "update mm set aa=4,arr=@blobData where aa=4;";
12 string insertStr = "insert into mm(arr) values(@blobData);";//需要主键设置自增
13 MySqlParameter par=new MySqlParameter("@blobData",MySqlDbType.Blob);
14 par.Value=byteArr;
15 MySqlCommand cmd = new MySqlCommand(insertStr, conn);
16 cmd.Parameters.Add(par);
17 try
18 {
19 conn.Open();
20 cmd.ExecuteNonQuery();
21 ms.Close();
22 ms.Dispose();
23 }
24 catch (Exception ep)
25 {
26 MessageBox.Show(ep.Message);
27 }
28 
29 
30 }
31 
32 private void button2_Click(object sender, EventArgs e)
33 {
34 BinaryFormatter bFormatter = new BinaryFormatter();
35 
36 MySql.Data.MySqlClient.MySqlDataReader myData;
37 MySqlConnection conn = new MySql.Data.MySqlClient.MySqlConnection(Properties.Settings.Default.MySqlConnectString);
38 string readStr = "select arr from mm where id =6;";
39 MySqlCommand cmd = new MySqlCommand(readStr, conn);
40 try
41 {
42 conn.Open();
43 myData = cmd.ExecuteReader();
44 if (!myData.HasRows)
45 {
46 throw new Exception("没有blob数据");
47 }
48 myData.Read();
49 byte[] blob = new byte[myData.GetBytes(0, 0, null, 0, int.MaxValue)];
50 myData.GetBytes(0, 0, blob, 0, blob.Length);
51 myData.Close();
52 ms = new System.IO.MemoryStream(blob);
53 ms.Position = 0;
54 int[] arr = (int[])bFormatter.Deserialize(ms);
55 ms.Dispose();
56 string arrStr = null;
57 for (int i = 0; i < arr.GetLength(0); i++)
58 {
59 arrStr += arr[i].ToString()+" ";
60 }
61 MessageBox.Show(arrStr);
62 }
63 catch(Exception ep)
64 {
65 MessageBox.Show(ep.Message);
66 }
67 
68 } 

代码中的连接字符串存储于Settings中,具体格式为:“server=127.0.0.1;user=root;database=***;port=3306;password=***;”。数据库中存在叫做mm的一个表格,含有一个id字段(主键,自增),一个arr字段(blob类型)。

上述代码将一个整型数组{1,2,3}序列化之后以blob数据类型存储在MySQL数据库中,进一步,又从MySQL数据库中读取blob数据,进行反序列化,得到整型数组{1,2,3}。代码执行结果如下:

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

C#实现MySQL数据库中的blob数据存储_MySQL

C#实现MySQL数据库中的blob数据存储_MySQL:在MySQL数据库中,有一种blob数据类型,用来存储文件。C#编程语言操作MySQL数据库需要使用MySQL官方组件MySQL.Data.dll。 Mysql.Data.dll(6.9.6)组件下载地址:http://download.csdn.net/detail/keypig_zz/9262767。
推荐度:
标签: 数据 数据库 mysql
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top