濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法

將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法

熱門標(biāo)簽:電話機(jī)器人市場(chǎng)趨勢(shì) 昆明電信400電話辦理 電銷機(jī)器人 行業(yè) 電銷機(jī)器人各個(gè)細(xì)節(jié)介紹 溫州瑞安400電話怎么申請(qǐng) 南昌高頻外呼系統(tǒng)哪家公司做的好 百度地圖標(biāo)注后不顯示 俄國(guó)地圖標(biāo)注app 淄博400電話申請(qǐng)

通常對(duì)用戶上傳的圖片需要保存到數(shù)據(jù)庫(kù)中。

解決方法一般有兩種:

1、將圖片保存的路徑存儲(chǔ)到數(shù)據(jù)庫(kù);

2、將圖片以二進(jìn)制數(shù)據(jù)流的形式直接寫入數(shù)據(jù)庫(kù)字段中。

以下為具體方法:

一、保存圖片的上傳路徑到數(shù)據(jù)庫(kù):

  string uppath="";//用于保存圖片上傳路徑
  //獲取上傳圖片的文件名
  string fileFullname = this.FileUpload1.FileName;
  //獲取圖片上傳的時(shí)間,以時(shí)間作為圖片的名字可以防止圖片重名
  string dataName = DateTime.Now.ToString("yyyyMMddhhmmss");
  //獲取圖片的文件名(不含擴(kuò)展名)
  string fileName = fileFullname.Substring(fileFullname.LastIndexOf("\\") + 1);
  //獲取圖片擴(kuò)展名
  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);
   //將路徑保存到變量,將該變量的值保存到數(shù)據(jù)庫(kù)相應(yīng)字段即可
   uppath = "~/upload/" + dataName + "." + type;
  }

二、將圖片以二進(jìn)制數(shù)據(jù)流直接保存到數(shù)據(jù)庫(kù):

引用如下命名空間:

    using System.Drawing;
  using System.IO;
  using System.Data.SqlClient;
  設(shè)計(jì)數(shù)據(jù)庫(kù)時(shí),表中相應(yīng)的字段類型為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 )";//操作數(shù)據(jù)庫(kù)語(yǔ)句根據(jù)需要修改
  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();
  讀取:
  ...連接數(shù)據(jù)庫(kù)字符串省略
  mycon.Open();
  SqlCommand command = new
  SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查詢語(yǔ)句根據(jù)需要修改
  byte[] image = (byte[])command.ExecuteScalar ();
  //指定從數(shù)據(jù)庫(kù)讀取出來(lái)的圖片的保存路徑及名字
  string strPath = "~/Upload/zhangsan.JPG";
  string strPhotoPath = Server.MapPath(strPath);
  //按上面的路徑與名字保存圖片文件
  BinaryWriter bw = new BinaryWriter(File.Open(strPhotoPath,FileMode.OpenOrCreate));
  bw.Write(image);
  bw.Close();
  //顯示圖片
  this.Image1.ImageUrl = strPath;
  //采用這兩種方式可以根據(jù)實(shí)際需求靈活選擇。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

您可能感興趣的文章:
  • MySQL中可為空的字段設(shè)置為NULL還是NOT NULL
  • MySQL中字段類型char、varchar和text的區(qū)別
  • MySQL數(shù)據(jù)庫(kù)遷移快速導(dǎo)出導(dǎo)入大量數(shù)據(jù)
  • shell腳本操作mysql數(shù)據(jù)庫(kù)刪除重復(fù)的數(shù)據(jù)
  • MySQL實(shí)現(xiàn)類似Oracle序列的方案
  • mysql實(shí)現(xiàn)sequence功能的代碼
  • Can''t connect to local MySQL through socket ''/tmp/mysql.sock''解決方法
  • Mysql常用函數(shù)大全(分類匯總講解)
  • 利用MySQL主從配置實(shí)現(xiàn)讀寫分離減輕數(shù)據(jù)庫(kù)壓力
  • MySQL關(guān)于sql_mode解析與設(shè)置講解

標(biāo)簽:安徽 吐魯番 拉薩 甘南 葫蘆島 洛陽(yáng) 嘉峪關(guān)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法》,本文關(guān)鍵詞  將,圖片,儲(chǔ),存在,MySQL,數(shù)據(jù)庫(kù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于將圖片儲(chǔ)存在MySQL數(shù)據(jù)庫(kù)中的幾種方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    遂溪县| 东乌珠穆沁旗| 南和县| 望谟县| 耿马| 邵阳市| 庆城县| 文登市| 泸溪县| 玉山县| 昌吉市| 铅山县| 三门县| 梅州市| 临海市| 永顺县| 通道| 广平县| 分宜县| 黄陵县| 四平市| 林甸县| 新泰市| 鲁甸县| 綦江县| 册亨县| 浠水县| 漳平市| 霍山县| 荥阳市| 大石桥市| 抚松县| 鄂伦春自治旗| 木兰县| 庄浪县| 星子县| 南通市| 昭觉县| 南开区| 桐城市| 天全县|