首頁 >資料庫 >mysql教程 >如何使用 C# 將影像儲存在資料庫中?

如何使用 C# 將影像儲存在資料庫中?

DDD
DDD原創
2024-12-30 22:43:10151瀏覽

How to Store Images in a Database Using C#?

使用 C# 將影像儲存在資料庫中

正在尋求將使用者影像保存在 C# 資料庫中的解決方案?本綜合指南將提供完成此任務的步驟和即用方法。

方法概述

下面概述的方法利用位元組數組來儲存影像資料並利用 IDataParameter 將二進位資料插入資料庫。

using System.Drawing;
using System.Drawing.Imaging;
using System.Data;

public static void PersistImage(string path, IDbConnection connection)
{
    using (var command = connection.CreateCommand ())
    {
        Image img = Image.FromFile (path);
        MemoryStream tmpStream = new MemoryStream();
        img.Save (tmpStream, ImageFormat.Png); // modify to desired format
        tmpStream.Seek (0, SeekOrigin.Begin);
        byte[] imgBytes = new byte[MAX_IMG_SIZE];
        tmpStream.Read (imgBytes, 0, MAX_IMG_SIZE);

        command.CommandText = "INSERT INTO images(payload) VALUES (:payload)";
        IDataParameter par = command.CreateParameter();
        par.ParameterName = "payload";
        par.DbType = DbType.Binary;
        par.Value = imgBytes;
        command.Parameters.Add(par);
        command.ExecuteNonQuery ();
    }
}

方法說明

  1. 建立一個位元組數組(imgBytes)來儲存映像資料。
  2. 從指定檔案路徑取得影像並儲存到記憶體流(tmpStream) .
  3. 重設流位置並將影像位元組讀入imgBytes陣列。
  4. 建構 SQL 指令以將影像負載插入資料庫。
  5. 建立名為「payload」的 IDataParameter 並設定其屬性以儲存二進位資料。
  6. 新增將參數傳遞給 SQL 命令並執行它來保存映像。

透過利用這種強大的方法,開發人員可以將影像無縫地保存到他們的資料庫中以進行進一步處理、儲存或檢索。

以上是如何使用 C# 將影像儲存在資料庫中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn