欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年03月04日 10:53:16   作者:baiduoWang  
今天小編就為大家分享一篇關于將圖片儲存在MySQL數(shù)據(jù)庫中的幾種方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

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

解決方法一般有兩種:

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

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

以下為具體方法:

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

  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);
   //將路徑保存到變量,將該變量的值保存到數(shù)據(jù)庫相應字段即可
   uppath = "~/upload/" + dataName + "." + type;
  }

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

引用如下命名空間:

    using System.Drawing;
  using System.IO;
  using System.Data.SqlClient;
  設計數(shù)據(jù)庫時,表中相應的字段類型為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ù)庫語句根據(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ù)庫字符串省略
  mycon.Open();
  SqlCommand command = new
  SqlCommand("select stuimage from stuInfo where stuid=107", mycon);//查詢語句根據(jù)需要修改
  byte[] image = (byte[])command.ExecuteScalar ();
  //指定從數(shù)據(jù)庫讀取出來的圖片的保存路徑及名字
  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ù)實際需求靈活選擇。

總結(jié)

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

相關文章

  • MySQL詳解進行JDBC編程與增刪改查方法

    MySQL詳解進行JDBC編程與增刪改查方法

    JDBC是指Java數(shù)據(jù)庫連接,是一種標準Java應用編程接口( JAVA API),用來連接 Java 編程語言和廣泛的數(shù)據(jù)庫。從根本上來說,JDBC 是一種規(guī)范,它提供了一套完整的接口,允許便攜式訪問到底層數(shù)據(jù)庫
    2022-06-06
  • Mac下忘記mysql密碼重新設置密碼的圖文教程

    Mac下忘記mysql密碼重新設置密碼的圖文教程

    這篇文章主要介紹了Mac下忘記mysql密碼重新設置密碼的教程,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-12-12
  • mysql SELECT FOR UPDATE語句使用示例

    mysql SELECT FOR UPDATE語句使用示例

    本文介紹在mysql中使用mysql SELECT FOR UPDATE 語句時的一些問題與解決辦法
    2013-11-11
  • Window下Mysql忘記root密碼怎么重置

    Window下Mysql忘記root密碼怎么重置

    這篇文章主要介紹了Window下Mysql忘記root密碼的重置方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • MySQL 發(fā)生同步延遲時Seconds_Behind_Master還為0的原因

    MySQL 發(fā)生同步延遲時Seconds_Behind_Master還為0的原因

    騰訊云數(shù)據(jù)庫 MySQL 的只讀實例出現(xiàn)了同步延遲,但是監(jiān)控的延遲時間顯示為 0,而且延遲的 binlog 距離非 0,且數(shù)值越來越大。臨時解決之后,仔細想了一想,Seconds_Behind_Master 雖然計算方式有點坑,但是出現(xiàn)這么“巨大”的誤差還是挺奇怪的,本文就來分析下這個問題
    2021-06-06
  • MySQL錯誤提示:sql_mode=only_full_group_by完美解決方案

    MySQL錯誤提示:sql_mode=only_full_group_by完美解決方案

    有時候遇到數(shù)據(jù)庫重復數(shù)據(jù),需要將數(shù)據(jù)進行分組,并取出其中一條來展示,這時就需要用到group by語句,下面這篇文章主要給大家介紹了關于MySQL錯誤提示:sql_mode=only_full_group_by的完美解決方案,需要的朋友可以參考下
    2022-10-10
  • mysql xtrabackup 備份恢復實現(xiàn)分享

    mysql xtrabackup 備份恢復實現(xiàn)分享

    Xtrabackup是由percona提供的mysql數(shù)據(jù)庫備份工具,據(jù)官方介紹,這也是世界上惟一一款開源的能夠?qū)nnodb和xtradb數(shù)據(jù)庫進行熱備的工具
    2012-11-11
  • 一文讀懂MySQL?表分區(qū)

    一文讀懂MySQL?表分區(qū)

    MySQL自帶了分區(qū)功能,我們可以創(chuàng)建一個帶有分區(qū)的表,而且不需要借助任何外部工具,本文主要了介紹了MySQL表分區(qū),具有一定的參考價值,感興趣的小伙伴們可以參考一下<BR>
    2022-03-03
  • 使用limit,offset分頁場景時為什么會慢

    使用limit,offset分頁場景時為什么會慢

    這篇文章主要介紹了使用limit,offset分頁場景時為什么會慢,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • SQL實現(xiàn)對數(shù)據(jù)庫檢索數(shù)據(jù)的直接轉(zhuǎn)換計算

    SQL實現(xiàn)對數(shù)據(jù)庫檢索數(shù)據(jù)的直接轉(zhuǎn)換計算

    這篇文章主要介紹了SQL實現(xiàn)對數(shù)據(jù)庫檢索數(shù)據(jù)的直接轉(zhuǎn)換計算,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09

最新評論