1.MySQL下可通過blob,mediumbolb,longblob等類型來儲存圖片
2.不同的圖片檔案類似操作會有所不同,例如.bmp格式圖片
範例程式碼:
//儲存圖片到MySQL
private void btnOpenFile_Click(object sender, EventArgs e)
{
//開啟圖片檔案
this.openFileDialog1.InitialDirectory = "C:\\";
this.openFileDialog1.FileName = "";
this.openFileDialog1.ShowDialog();
//連接字串
string connStr = "server=vitus;User Id=root;Password=******;Persist Security Info=True;database=Test";
string sql = string.Format("insert into ImageTest values(@id,@picture)");
FileStream fs = new FileStream(this.openFileDialog1.FileName,FileMode.Open);
Byte[] bts = new Byte[fs.Length-1];
fs.Read(bts,0,(int)fs.Length-1);
MySqlConnection sqlConn = new MySqlConnection(connStr);
MySqlCommand sqlComm = new MySqlCommand(sql,sqlConn);
sqlComm.Parameters.Add("@id", MySqlDbType.Int32, 1);
sqlComm.Parameters["@id"].Value = 2;
sqlComm.Parameters.AddWithValue("@picture", bts);
sqlConn.Open();
sqlComm.ExecuteNonQuery();
sqlConn.Clone();
}
//從MySQL中讀取並顯示圖片
private void btnImageView_Click(object sender, EventArgs e)
{
string connStr = "server=vitus;User Id=root;Password=******;Persist Security Info=True;database=Test";
string sql = string.Format("select * from ImageTest where id=2");
MySqlConnection sqlConn = new MySqlConnection(connStr);
MySqlCommand sqlComm = new MySqlCommand(sql, sqlConn);
sqlConn.Open();
MySqlDataReader dr = sqlComm.ExecuteReader(CommandBehavior.CloseConnection);
Image image = null;
while (dr.Read())
{
MemoryStream buff = new MemoryStream((byte[])dr[1]);
image = Image.FromStream(buff, true);
buff.Close();
}
this.pictureBox1.Image = image;
}