C#中RichEdit控件,保存文本和图片到mysql数据库
分別通過內存流和RTF文件保存,個人感覺是較為完善的兩種方法,希望大家可以用得到,有什么技術分享,歡迎下面留言
方法1:
//建立內存流
MemoryStream ms = new MemoryStream();
//ms.Position = 0;
//把當前的richtextbox內容包括圖片和文本保存到流中
richTextBox1.SaveFile(ms, RichTextBoxStreamType.RichText);
byte[] buffer = ms.GetBuffer();
// MySqlConnectString
MySqlConnection conn = new MySqlConnection(Properties.Settings.Default.MySqlConnectString);
string insertStr = "insert into httang_test.hxwang_richedit(image) values(@blobData);";//需要主鍵設置自增
MySqlParameter par = new MySqlParameter("@blobData", MySqlDbType.Blob);
par.Value = buffer;
MySqlCommand cmd = new MySqlCommand(insertStr, conn);
cmd.Parameters.Add(par);
try
{
conn.Open();
cmd.ExecuteNonQuery();
ms.Close();
ms.Dispose();
}
catch (Exception ep)
{
MessageBox.Show(ep.Message);
}
richTextBox1.Clear();
MessageBox.Show("成功插入數據庫!");
}
方法2:
if ((Path.GetExtension("D:\\text")).ToLower() == ".rtf")
richTextBox1.SaveFile("D:\\text", RichTextBoxStreamType.RichNoOleObjs);
else
richTextBox1.SaveFile("D:\\text");
FileStream fs = new FileStream("D:\\text", FileMode.Open);
BinaryReader br = new BinaryReader(fs);
byte[] byData = br.ReadBytes((int)fs.Length);
//byte[] buffer = ms.GetBuffer();
MySqlConnectString
MySqlConnection conn = new MySqlConnection(Properties.Settings.Default.MySqlConnectString);
string insertStr = "insert into httang_test.hxwang_richedit(image) values(@blobData);";//需要主鍵設置自增
MySqlParameter par = new MySqlParameter("@blobData", MySqlDbType.Blob);
par.Value = byData;
MySqlCommand cmd = new MySqlCommand(insertStr, conn);
cmd.Parameters.Add(par);
try
{
conn.Open();
cmd.ExecuteNonQuery();
fs.Close();
fs.Dispose();
}
catch (Exception ep)
{
MessageBox.Show(ep.Message);
}
richTextBox1.Clear();
MessageBox.Show("成功插入數據庫!");
}
}
轉載于:https://www.cnblogs.com/wanghx-0713/p/7878711.html
總結
以上是生活随笔為你收集整理的C#中RichEdit控件,保存文本和图片到mysql数据库的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SourceTree 基本介绍
- 下一篇: mysql数据库的增删改查