>데이터 베이스 >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으로 문의하세요.