91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql數據庫怎樣儲存讀取圖片

發布時間:2020-11-04 10:00:45 來源:億速云 閱讀:166 作者:小新 欄目:MySQL數據庫

這篇文章主要介紹了mysql數據庫怎樣儲存讀取圖片,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

mysql儲存讀取圖片的方法:首先將圖片轉換成緩沖流;然后獲得圖片的字節數組并執行相關操作;最后通過“public void MapSearchQuery(out byte[] imageByteResulet){...}”讀取圖片即可。

   首先,介紹一下mysql相關的數據類型:MySQL中有四種BLOB類型,TinyBlob(最大255Byte), Blob(最大65K), MediunBlob(16M), LongBlob(最大4G)。這里注意一下如果你數據庫出現相關的Data too long...字樣可能是你選擇的種類的大小不夠。

   接下來簡單說一下我為什么沒有用存儲圖片路徑的方式,而采取了直接在MySQL中存儲圖片的方式。原因有兩點:

   1、本身不需要大量圖片,一個數據庫只需要一張圖片

   2、軟件結構是要通過WebService由一個主客戶端去訪問下面附屬的幾個客戶端,如果附屬客戶端不存儲圖片直接供主客戶端訪問,那么主客戶端勢必就需要一個加載圖片的功能(類似于FTP的功能)。

   下面還是直接上代碼吧:

public bool MapSearchWrite(string strImagePath)
         {
             //將圖片轉換成緩沖流
             FileStream fs = new FileStream(strImagePath, FileMode.Open, FileAccess.Read);
             
             //獲得圖片的字節數組
             byte[] byImage = new byte[fs.Length];
             fs.Read(byImage, 0, byImage.Length);
             fs.Close();
             //數據庫連接
             MySqlConnection conn = new MySqlConnection();
             conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
             try
             {
                 conn.Open();
             }
             catch
             {
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地圖檢索數據庫連接失敗");
             }
             //判斷數據庫內部有無記錄
             string strQueryCmd = "select PicNum from images";
             MySqlCommand cmdQuery = new MySqlCommand(strQueryCmd, conn);
             MySqlDataReader dataReader = cmdQuery.ExecuteReader();
             //執行操作
             MySqlCommand cmd = new MySqlCommand();
             if (dataReader.Read())
             {
                 cmd.CommandText = "update images set Image=@byImage";
             }
             else
             {
                 cmd.CommandText = "insert into images(Image) values(@byImage)";
             }
           
             cmd.CommandType = CommandType.Text;
             cmd.Parameters.Add("@byImage", MySqlDbType.MediumBlob);
             cmd.Parameters[0].Value = byImage;
             cmd.Connection = conn;
          
             int affectedRows = 0;
             try
             {
                 affectedRows = cmd.ExecuteNonQuery();
             }
             catch
             {
                 affectedRows = -1;
             }
             //關閉連接等
             cmd.Dispose();
             conn.Close();
             conn.Dispose();
             if (affectedRows <= 0)
             {
                 return false;
             }
             else
             {
                 return true;
             }
         }

   這是把圖片插入到數據庫的操作代碼,路徑的話就是你所需要存儲的圖片所在的路徑(包括圖片的名字和后綴名哦),另外我這里采用的是ADO.NET的連接方式,語言是C#的,其他代碼也不用我解釋了......

   下面是讀取MySQL中的圖片的代碼

 public void MapSearchQuery(out byte[] imageByteResulet)
         {
             imageByteResulet = null;
             MySqlConnection conn = new MySqlConnection();
             conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
             try
             {
                 conn.Open();
             }
             catch
             {
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地圖檢索數據庫連接失敗");
             }
             string strQueryCmd = "select Image from images limit 1";
             MySqlCommand cmd = new MySqlCommand(strQueryCmd, conn);
             MySqlDataReader dataReader = null;
             try
             {
                 dataReader = cmd.ExecuteReader();
             }
             catch
             {
                 dataReader.Dispose();
                 cmd.Dispose();
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地圖檢索查詢地圖失敗");
             }
             if (dataReader.Read())
             {
                 imageByteResulet = new byte[dataReader.GetBytes(0, 0, null, 0, int.MaxValue)];
                 dataReader.GetBytes(0, 0, imageByteResulet, 0, imageByteResulet.Length);
                 //將圖片字節數組加載入到緩沖流
                 // MemoryStream imageStream = new MemoryStream(imageByte);
                 //從緩沖流生成圖片
                 //imageResulet = Image.FromStream(imageStream, true);
             }
             dataReader.Dispose();
             cmd.Dispose();
             conn.Close();
             conn.Dispose();
         }

   當然這里我是照顧到Image對象不能通過WebService傳輸而把BLOB數據只轉換成byte[]在傳輸,如果不需要這個功能的換可以直接把相關代碼踢出來再將byte[]轉成圖片對象即可,一下提供兩種方法

第一種:imageByte是調用上面函數得到的byte[]的數據

//將圖片字節數組加載入到緩沖流  
MemoryStream imageStream = new MemoryStream(imageByte);
                //從緩沖流生成圖片                
                imageResulet = Image.FromStream(imageStream, true);
                //pictureBox是一個顯示圖片或者視頻的C#控件
                pictureBox.Image = imageResulet;

這樣就把圖片讀取出來并顯示出來了

第二種:BitMap是System.Drawingm命名空間中的

Bitmap bm = new Bitmap(new MemoryStream(
imageByte
));
            
    
 pictureBox1.Image = bm;

那么,到此我就說完了,當然不是迫不得已不要把圖片存到數據庫中,可以做個url映射,返回文件流。

感謝你能夠認真閱讀完這篇文章,希望小編分享mysql數據庫怎樣儲存讀取圖片內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台前县| 集安市| 大宁县| 于田县| 瑞丽市| 乌恰县| 阿克| 凤山县| 关岭| 红原县| 许昌市| 巴林右旗| 东海县| 陈巴尔虎旗| 康平县| 虎林市| 札达县| 大田县| 堆龙德庆县| 海宁市| 珲春市| 拉孜县| 梨树县| 丰县| 田林县| 乐山市| 惠来县| 万州区| 临武县| 紫阳县| 梁山县| 天门市| 新巴尔虎左旗| 鹰潭市| 赞皇县| 拜城县| 梓潼县| 奉化市| 基隆市| 兖州市| 定远县|