ホームページ  >  記事  >  データベース  >  mysqlに画像を保存して読み取る方法

mysqlに画像を保存して読み取る方法

藏色散人
藏色散人オリジナル
2020-11-03 10:07:233149ブラウズ

画像を読み取るための Mysql ストレージ メソッド: 最初に画像をバッファ ストリームに変換し、次に画像のバイト配列を取得して関連操作を実行し、最後に「public void MapSearchQuery(out byte[] imageByteResulet){」を渡します。 . .}" 画像を読んでください。

mysqlに画像を保存して読み取る方法

おすすめ: 「mysql ビデオ チュートリアル

まず、mysql 関連のデータを紹介します。 type: MySQL には、TinyBlob (最大 255Byte)、Blob (最大 65K)、MediunBlob (16M)、LongBlob (最大 4G) の 4 つの BLOB タイプがあります。 ここで、関連するデータが長すぎる... 単語がデータベースに表示される場合は、選択したタイプのサイズが十分ではない可能性があることに注意してください。

次に、なぜ画像のパスを保存する方法を使わず、MySQL に直接画像を保存する方法を採用したのかについて簡単に説明します。理由は 2 つあります。

1. 大量の画像は必要ありません。データベースに必要な画像は 1 つだけです。

2.ソフトウェア構造は、メインクライアントがWebServiceを通じて以下の複数の所属クライアントにアクセスすることになっており、所属クライアントがメインクライアントから直接アクセスできる画像を保存していない場合、メインクライアントには必然的に画像を読み込む機能(FTP機能と同様)が必要となります。 ######)。

コードに直接進みましょう:

public bool MapSearchWrite(string strImagePath)
         {
             //将图片转换成缓冲流
             FileStream fs = new FileStream(strImagePath, FileMode.Open, FileAccess.Read);
             
             //获得图片的字节数组
             byte[] byImage = new byte[fs.Length];
             fs.Read(byImage, 0, byImage.Length);
             fs.Close();
             //数据库连接
             MySqlConnection conn = new MySqlConnection();
             conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
             try
             {
                 conn.Open();
             }
             catch
             {
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地图检索数据库连接失败");
             }
             //判断数据库内部有无记录
             string strQueryCmd = "select PicNum from images";
             MySqlCommand cmdQuery = new MySqlCommand(strQueryCmd, conn);
             MySqlDataReader dataReader = cmdQuery.ExecuteReader();
             //执行操作
             MySqlCommand cmd = new MySqlCommand();
             if (dataReader.Read())
             {
                 cmd.CommandText = "update images set Image=@byImage";
             }
             else
             {
                 cmd.CommandText = "insert into images(Image) values(@byImage)";
             }
           
             cmd.CommandType = CommandType.Text;
             cmd.Parameters.Add("@byImage", MySqlDbType.MediumBlob);
             cmd.Parameters[0].Value = byImage;
             cmd.Connection = conn;
          
             int affectedRows = 0;
             try
             {
                 affectedRows = cmd.ExecuteNonQuery();
             }
             catch
             {
                 affectedRows = -1;
             }
             //关闭连接等
             cmd.Dispose();
             conn.Close();
             conn.Dispose();
             if (affectedRows <= 0)
             {
                 return false;
             }
             else
             {
                 return true;
             }
         }

これは、データベースに画像を挿入するためのオペレーション コードです。パスはストレージです。画像が配置されているパス (画像の名前とサフィックスを含む) さらに、ADO.NET 接続メソッドを使用し、言語は C# です。他のコードについては説明する必要はありません...

以下は、MySQL で画像を読み取るためのコードです。

 public void MapSearchQuery(out byte[] imageByteResulet)
         {
             imageByteResulet = null;
             MySqlConnection conn = new MySqlConnection();
             conn.ConnectionString = "Server=localhost;Uid=root;Password=123456;Database=firefighting;charset=gb2312";
             try
             {
                 conn.Open();
             }
             catch
             {
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地图检索数据库连接失败");
             }
             string strQueryCmd = "select Image from images limit 1";
             MySqlCommand cmd = new MySqlCommand(strQueryCmd, conn);
             MySqlDataReader dataReader = null;
             try
             {
                 dataReader = cmd.ExecuteReader();
             }
             catch
             {
                 dataReader.Dispose();
                 cmd.Dispose();
                 conn.Close();
                 conn.Dispose();
                 throw new ArgumentException("地图检索查询地图失败");
             }
             if (dataReader.Read())
             {
                 imageByteResulet = new byte[dataReader.GetBytes(0, 0, null, 0, int.MaxValue)];
                 dataReader.GetBytes(0, 0, imageByteResulet, 0, imageByteResulet.Length);
                 //将图片字节数组加载入到缓冲流
                 // MemoryStream imageStream = new MemoryStream(imageByte);
                 //从缓冲流生成图片
                 //imageResulet = Image.FromStream(imageStream, true);
             }
             dataReader.Dispose();
             cmd.Dispose();
             conn.Close();
             conn.Dispose();
         }

もちろん、私はそうします。 WebService送信ではBLOBデータをbyte[]に変換して送信するだけなので、この機能が不要な場合は直接該当コードをキックアウトしてbyte[]をピクチャオブジェクトに変換することも可能です。メソッドが提供されています

最初のメソッド: imageByte は、上記の関数を呼び出して取得された byte[] データです。

//将图片字节数组加载入到缓冲流  
MemoryStream imageStream = new MemoryStream(imageByte);
                //从缓冲流生成图片                
                imageResulet = Image.FromStream(imageStream, true);
                //pictureBox是一个显示图片或者视频的C#控件
                pictureBox.Image = imageResulet;

画像が読み取られて表示されます

2 番目のタイプ: BitMap は System.Drawingm 名前空間の

Bitmap bm = new Bitmap(new MemoryStream(
imageByte
));
            
    
 pictureBox1.Image = bm;

ですさて、これで完了です。もちろん、画像をデータベースに保存する必要はありません。URL マッピングを作成してファイル ストリームを返すことができます (私はまだこれを試していません。私の経験を共有します)時間があったらみんな)。

以上がmysqlに画像を保存して読み取る方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。