mysql可以存儲圖片,并且有兩種存儲方法,分別是:1、將圖片保存的路徑存儲到數據庫;2、將圖片以二進制數據流的形式直接寫入數據庫字段中。
MySQL是一個關系型數據庫管理系統,由瑞典MySQL AB 公司開發,目前屬于?oracle?旗下產品。它的功能很強大,其中有些功能大家可能不是很清楚,比如它也是可以存儲圖片,這一點你知道嗎?
可以存儲圖片。在mysql存儲圖片的方法一般有兩種:其一,將圖片保存的路徑存儲到數據庫;其二,將圖片以二進制數據流的形式直接寫入數據庫字段中。
一、保存圖片的上傳路徑到數據庫:
string?uppath="";//用于保存圖片上傳路徑 //獲取上傳圖片的文件名 string?fileFullname?=?this.FileUpload1.FileName; //獲取圖片上傳的時間,以時間作為圖片的名字可以防止圖片重名 string?dataName?=?DateTime.Now.ToString("yyyyMMddhhmmss"); //獲取圖片的文件名(不含擴展名) string?fileName?=?fileFullname.Substring(fileFullname.LastIndexOf("")?+?1); //獲取圖片擴展名 string?type?=?fileFullname.Substring(fileFullname.LastIndexOf(".")?+?1); //判斷是否為要求的格式 if?(type?==?"bmp"?||?type?==?"jpg"?||?type?==?"jpeg"?||?type?==?"gif"?||?type?==?"JPG"?||?type?==?"JPEG"?||?type?==?"BMP"?||?type?==?"GIF") { ?//將圖片上傳到指定路徑的文件夾 ?this.FileUpload1.SaveAs(Server.MapPath("~/upload")?+?""?+?dataName?+?"."?+?type); ?//將路徑保存到變量,將該變量的值保存到數據庫相應字段即可 ?uppath?=?"~/upload/"?+?dataName?+?"."?+?type; }
二、將圖片以二進制數據流直接保存到數據庫:
引用如下命名空間:
using?System.Drawing; using?System.IO; using?System.Data.SqlClient;
設計數據庫時,表中相應的字段類型為iamge
保存:
//圖片路徑 string?strPath?=?this.FileUpload1.PostedFile.FileName.ToString?(); //讀取圖片 FileStream?fs?=?new?System.IO.FileStream(strPath,?FileMode.Open,?FileAccess.Read); BinaryReader?br?=?new?BinaryReader(fs); byte[]?photo?=?br.ReadBytes((int)fs.Length); br.Close(); fs.Close(); //存入 SqlConnection?myConn?=?new?SqlConnection("Data?Source=.;Initial?Catalog=stumanage;User?ID=sa;Password=123"); string?strComm?=?"?INSERT?INTO?stuInfo(stuid,stuimage)?VALUES(107,@photoBinary?)";//操作數據庫語句根據需要修改 SqlCommand?myComm?=?new?SqlCommand(strComm,?myConn); myComm.Parameters.Add("@photoBinary",?SqlDbType.Binary,?photo.Length); myComm.Parameters["@photoBinary"].Value?=?photo; myConn.Open(); if?(myComm.ExecuteNonQuery()?>?0) { ?this.Label1.Text?=?"ok"; } myConn.Close();
采用這兩種方式可以根據實際需求靈活選擇。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END