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

溫馨提示×

溫馨提示×

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

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

將圖片儲存在MySQL數據庫中的幾種方法

發布時間:2020-10-04 14:17:23 來源:腳本之家 閱讀:2015 作者:baiduoWang 欄目:MySQL數據庫

通常對用戶上傳的圖片需要保存到數據庫中。

解決方法一般有兩種:

1、將圖片保存的路徑存儲到數據庫;

2、將圖片以二進制數據流的形式直接寫入數據庫字段中。

以下為具體方法:

一、保存圖片的上傳路徑到數據庫:

  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();
  讀取:
  ...連接數據庫字符串省略
  mycon.Open();
  SqlCommand command = new
  SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查詢語句根據需要修改
  byte[] image = (byte[])command.ExecuteScalar ();
  //指定從數據庫讀取出來的圖片的保存路徑及名字
  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;
  //采用這兩種方式可以根據實際需求靈活選擇。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

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

AI

南昌市| 蓝田县| 策勒县| 武宣县| 子长县| 清水县| 神农架林区| 靖江市| 和硕县| 兴隆县| 萨嘎县| 沙洋县| 西昌市| 苏尼特右旗| 华亭县| 泰州市| 郁南县| 神木县| 扬州市| 巴南区| 泾川县| 梁河县| 宁波市| 兴文县| 惠来县| 类乌齐县| 新昌县| 景东| 滦平县| 吴堡县| 泾阳县| 紫金县| 东明县| 阜新市| 泸水县| 内乡县| 长丰县| 铁岭市| 弥渡县| 安丘市| 辽源市|