>  기사  >  데이터 베이스  >  MySQL의 BLOB으로 저장된 이미지를 PictureBox에 표시하는 방법은 무엇입니까?

MySQL의 BLOB으로 저장된 이미지를 PictureBox에 표시하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-28 17:55:02464검색

How to Display an Image Stored as a BLOB in MySQL in a PictureBox?

MySQL에서 이미지를 검색하여 PictureBox에 표시하는 방법

문제:

BLOB으로 저장된 이미지 검색 MySQL 데이터베이스에 저장하고 PictureBox에 표시하는 것이 올바르게 작동하지 않습니다.

해결책:

제공된 코드의 문제는 MySQL 데이터베이스에서 이미지를 잘못 검색하는 데 있습니다. 데이터베이스. 다음 단계에서는 MySQL 데이터베이스에서 이미지를 검색하고 표시하는 방법을 설명합니다.

  1. 데이터베이스 설정:

    • 다음에서 테이블을 생성합니다. 이미지 데이터를 BLOB 유형으로 저장하는 열이 있는 MySQL 데이터베이스.
  2. PictureBox에 이미지 표시:

    • byteArrayToImage 메서드에서 바이트 배열(ImageByte)을 Image 객체로 변환합니다.

      public Image byteArrayToImage(byte[] byteArrayIn)
      {
          using (var ms = new MemoryStream(byteArrayIn))
          {
              return Image.FromStream(ms);
          }
      }
    • photoLoad 메서드에서 매개변수화된 쿼리를 사용하여 이미지를 검색합니다.

      private void photoLoad()
      {
          // ...
          using (var con = new MySqlConnection(connectionString))
          {
              byte[] ImageByte = new byte[0];
              string query1 = "select image from reg.img_table where id= @id";
              using (var cmd = new MySqlCommand(query1, con))
              {
                  cmd.Parameters.AddWithValue("@id", Properties.Settings.Default.idImg);
                  
                  con.Open();
                  using (var row = cmd.ExecuteReader())
                  {
                      while (row.Read())
                      {
                          ImageByte = (byte[])(row["image"]);
                      }
                  }
              }
      
              if (ImageByte != null)
              {
                  // Convert to an Image object and display in PictureBox
                  roundPictureBox1.Image = byteArrayToImage(ImageByte);
                  roundPictureBox1.Refresh();
              }
          }
          // ...
      }
  3. 추가 고려 사항:

    • 이미지가 데이터베이스에 올바르게 저장되고 있는지 확인하세요( 예를 들어 File.ReadAllBytes를 사용하여 이미지 파일을 읽습니다.
    • 이미지 개체로 변환하기 전에 검색된 바이트 배열(ImageByte)이 비어 있지 않은지 확인하세요.
    • 예외를 적절하게 처리합니다. 오류 처리를 위해 photoLoad 메서드에

위 내용은 MySQL의 BLOB으로 저장된 이미지를 PictureBox에 표시하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.