【轉載】C#將圖片以二進位流的方式存入資料庫

来源:https://www.cnblogs.com/xu-yi/archive/2019/03/20/10564320.html
-Advertisement-
Play Games

在C#開發應用程式的過程中,圖片一般會存放在文件系統中,當然圖片也可以二進位的方式存放到資料庫中,不過一般不建議存放在資料庫中,因為圖片占用的空間還是挺大的,特殊情況下可以考慮將圖片存在數據。此文將介紹如何將圖片存放在Sqlserver資料庫中,並從資料庫中讀取出圖片信息。 在將圖片存儲到資料庫之前 ...


在C#開發應用程式的過程中,圖片一般會存放在文件系統中,當然圖片也可以二進位的方式存放到資料庫中,不過一般不建議存放在資料庫中,因為圖片占用的空間還是挺大的,特殊情況下可以考慮將圖片存在數據。此文將介紹如何將圖片存放在Sqlserver資料庫中,並從資料庫中讀取出圖片信息。

在將圖片存儲到資料庫之前,需要先設計資料庫表,建議使用sqlserver的數據類型Image類型存儲數據,當然也有人使用二進位binary類型存儲。

一、將圖片寫入資料庫中的方法

在此方法中使用到FileStream類,該類在此的作用是將圖片讀取到文件流中。具體實現方法如下:

 public void WriteImgToDb()
{
  SqlConnection conn=new SqlConnection("server=.;database=pubs;trusted_connection=Yes"); 
  conn.Open(); 
  SqlCommand scmd = null; 
  string Path = Application.StartupPath + "//Imgren"; //為獲取文件的根目錄 
  int j = 0; 
  FileStream fs=null; 
  for (int i = 1; i  <= 13; i++)  //利用迴圈添加一次添加圖片 
  { 
      string sql = "insert into tb_Image values(@a,@b)"; //利用參數實現圖片添加 
      scmd = new SqlCommand(sql, scon); 
  
      scmd.Parameters.Add("@a", SqlDbType.Int); 
      scmd.Parameters["@a"].Value = i;   //記住該方法,將值存入參數內 
  
      byte[] bt = new byte[10240];       //初始化圖片大小 
      //創建圖片寫入流 
      fs = new FileStream(Path + "//" + i + ".bmp", FileMode.OpenOrCreate, FileAccess.Read); 
      fs.Read(bt, 0, bt.Length);  //讀取圖片的位元組數 
      scmd.Parameters.Add("@b", SqlDbType.Image, (int)fs.Length); 
      scmd.Parameters["@b"].Value = bt; //將圖片的位元組數存入參數內 
      j = scmd.ExecuteNonQuery(); 
   } 
  if (j > 0) 
      MessageBox.Show("將圖片寫入資料庫成功!!!", "友好提示"); 
  else 
      MessageBox.Show("將圖片寫入資料庫失敗!!!", "友好提示"); 
  fs.Close(); //關閉釋放流資源 
}

二、將從資料庫中讀取圖片到picturebox控制項中(WinForm窗體控制項)。

此方法使用了MemoryStream類即記憶體流對象,同時使用了Image類,Image類是.NET Framework內部提供的圖片相關類。從Sqlserver資料庫中讀取圖片數據具體實現方法如下:

public void ReadDbImage()
{
  SqlConnection conn=new SqlConnection("server=.;database=pubs;trusted_connection=Yes"); 
     conn.Open(); 
     SqlCommand scmd = null; 
     string sql = "select I_image from tb_image where I_id=" +int.Parse(textBox1.Text.Trim()) + ""; 
     scmd = new SqlCommand(sql, scon); 
     SqlDataReader red = scmd.ExecuteReader(); 
     if (red.Read()) 
     { 
       //創建支持存儲區的記憶體流 
        MemoryStream ms = new MemoryStream((byte[])red[0]); 
        Image img = Image.FromStream(ms, true); //該方法: FromStream()為驗證圖像的流 
        this.pictureBox1.Image = img; 
     } 
     red.Close(); //關閉資源 
}

 

擴展閱讀:C#工具類:使用SharpZipLib進行壓縮、解壓文件微軟官方提供的Sqlserver資料庫操作幫助類SQLHelper類

備註:原文轉載自C#將圖片以二進位流的方式存入資料庫_IT技術小趣屋


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 什麼是委托。 委托是一種數據類型。 委托的作用。 把變化的東西封裝起來。 委托是引用變數,聲明後不賦值為null 所以使用前校驗非空。 目前來看,委托沒啥毛用,直接調用M1不就得了? 下麵程式的作用是,傳入一個字元串,把每個人名都加上* 但是現在需求變了,把每個人名都換成大寫。 就需要改變代碼。 而 ...
  • DateTime dt =......//減數DateTime dt_n = DateTime.Now;//被減數long x = dt .ToFileTime();//表示自協調世界時 (UTC) 公元 (C.E.) 1601 年 1 月 1 日午夜 12:00 以來已經過的是協調世界時 (UTC ...
  • 因為條形碼有不同的編碼格式,使用時要註意編碼格式。首先在 NuGet包管理器中引用下載BarcodeLib.dll文件。BarcodeLib.dll一維條碼庫,支持以下條碼格式:UPC-A,UPC-E,UPC 2 Digit Ext,UPC 5 Digit Ext.,EAN-13,JAN-13,EA ...
  • www.smobiler.com 什麼是企業移動應用? 能夠通過一種方式來為客戶、合作伙伴和員工交付信息和服務,從而幫助其增加收入,提高業務敏捷性和生產力的移動端產品,我們稱之為企業移動應用。 企業移動應用發展趨勢如何? 隨著科技不斷的發展進步,企業級移動應用產品開始走進人們的視野。有越來越多的大型 ...
  • 公司業務量越來越大,為了使公司的開發效率有一定的提高,老闆拍板由我牽頭開發了一個快速開發平臺。 我們主要做的是對OA、ERP、ERP等有一定需求的客戶,搭建出一個通用的後臺,再配合一些開發組件,能夠使工作輕鬆不少。 另外,老闆一再強調要對app進行支持,能一次部署到安卓和ios上,微信當然也不能落下 ...
  • 首先創建一個DataGridView控制項,然後創建列(包括列名的定義), 由於我不是和資料庫進行連接,只是為了輸出好看一點。 刪除所有數據: while (this.dataGridView1.Rows.Count != 0) { this.dataGridView1.Rows.RemoveAt(0 ...
  • 在VS中添加bartender的COM組件引用後(一定要添加,否則會提示找不到BarTender.Application): 如是遇到標簽等設置無誤,但仍然無法列印時,有可能存在以下問題: 1.印表機驅動有問題,需重裝驅動; 2.bartender在企業版中需要設置Seagull License S ...
  • 寫個重新載入 ocelot 配置的介面 Intro 我們想把 ocelot 的配置放在自己的存儲中,放在 Redis 或者資料庫中,當修改了 Ocelot 的配置之後希望即時生效,又不想在網關這邊定時刷新 ocelot 配置,ocelot 配置沒變化的時候,定時刷新配置是一種無意義的資源浪費,oce ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...