国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ADO.NET筆記——讀取二進制大對象(BLOB)

2024-07-21 02:47:34
字體:
來源:轉載
供稿:網友
ADO.NET筆記——讀取二進制大對象(BLOB)

相關知識:

  1. 在SQL Server中,一般情況下,每行數據的總長度不能超過8K字節。因此,下列數據類型的長度,也不能超過8K字節:binary,char(),nchar(),varchar(),nvarchar()。注意,由于nvarchar是Unicode字符,因此,其最大長度也不能超過nvarchar(4000)
  2. 對于超長數據,尤其是二進制數據(例如音頻視頻數據等),SQL Server提供了下列數據類型(可以超過8K):image,varbinary(max),text,ntext,varchar(max),nvarchar(max)
  3. 對于較小的二進制數據,可以公國DataReader或者DataSet一次性讀取。但是對于較大的二進制數據(BLOB),例如1MB以上,如果一次性把所有數據都讀取出來,就會消耗大量的程序內存(字節數組)。因此,往往是采用分批讀取的方式進行
  4. SqlDataReader的二進制讀?。?ul>
  5. 在ExecuteReader調用時,要指定CommandBehavior.Sequentialaccess選項,以表明通過順序的方式逐段讀取
     SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
  6. GetBytes函數,可以將二進制字段中的數據逐段讀到緩沖區中
  7. 應當優先把BLOB字段前的其他字段讀取出來,否則一旦開始讀BLOB字段,將無法再回頭去讀之前的字段

代碼示例:

  • 數據庫:采用紅皮書的示例數據庫,AdventureWorks_WroxSSRS2012,使用PRoduction.ProductPhoto表,獲取其中的圖片數據信息

   

  • 引入:
    using System.Data;using System.Data.SqlClient;using System.IO;

  • 基本定義:
    1         const int BUF_SIZE = 1024;//緩沖區大小2         static string strConn = @"server=Joe-PC;database=AdventureWorks_WroxSSRS2012;uid=sa;pwd=root";3         static SqlConnection conn = new SqlConnection(strConn);4         //優先把BLOB字段前的其他字段讀取出來,否則一旦開始讀BLOB字段,將無法再回頭去讀之前的字段(注意此sql語句中字段的順序與數據庫字段順序的對比)5         static string strCmd = "SELECT ProductPhotoID,ThumbnailPhotoFileName,ThumbNailPhoto,LargePhotoFileName,LargePhoto FROM Production.ProductPhoto";6         static SqlCommand cmd = new SqlCommand(strCmd, conn);

  • 訪問ProductPhoto表
     1         static void Main(string[] args) 2         { 3             try 4             { 5                 conn.Open(); 6                 //以SequentialAccesss方式打開DataReader 7                 SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess); 8                 while (dr.Read()) 9                 {10                     int productPhotoID = dr.GetInt32(0);11                     string thumbnailPhotoFileName = dr.GetString(1);//讀取縮略圖文件名12                     WriteThumbnailPhotoFile(thumbnailPhotoFileName, dr);//將縮略圖二進制數據寫入磁盤文件13                     string largePhotoFileName = dr.GetString(3);//讀取大圖文件名14                     WriteLargePhotoFile(largePhotoFileName, dr);//將大圖二進制數據寫入磁盤文件15                 }16             }17             catch (Exception e)18             {19                 Console.WriteLine(e);20             }21             finally22             {23                 conn.Close();24             }25         }

  • 將縮略圖二進制數據寫入磁盤文件的函數
    1         static void WriteThumbnailPhotoFile(string fileName, SqlDataReader dr)2         {3             string path = "..//..//images//Thumbnail//" + fileName;//需要預先在項目文件夾中建立此目錄4             FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write);5             //ThumbnailPhoto的數據比較小(沒有超過8KB),因此選擇一次性讀出,直接寫入文件6             byte[] buf = dr[2] as byte[];7             fs.Write(buf, 0, buf.Length);8             fs.Close();9         }

  • 將大圖二進制數據寫入磁盤文件的函數
     1         static void WriteLargePhotoFile(string fileName, SqlDataReader dr) 2         { 3             string path = "..//..//images//Large//" + fileName;//需要預先在項目文件夾中建立此目錄 4             FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write); 5             byte[] buf = new byte[BUF_SIZE]; 6             long bytesRead = 0; 7             long startIndex = 0; 8             //LargePhoto的數據比較大,因此分批次讀出,分別寫入文件 9             while ((bytesRead = dr.GetBytes(4, startIndex, buf, 0, BUF_SIZE)) > 0)10             {11                 fs.Write(buf, 0, (int)bytesRead);12                 startIndex += bytesRead;13             }14             fs.Close();15         }

程序說明:

需要預先在本項目文件夾下建立images目錄,內有thumbnail和large子目錄,用于存放從數據庫獲取的圖片


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄂伦春自治旗| 卢氏县| 包头市| 老河口市| 旺苍县| 麻栗坡县| 衡阳县| 遂川县| 北辰区| 连平县| 汾阳市| 青阳县| 绥宁县| 泗阳县| 孟村| 东台市| 青海省| 冀州市| 抚顺市| 定兴县| 永泰县| 临西县| 运城市| 绥德县| 余庆县| 民县| 诸城市| 肇州县| 墨竹工卡县| 古浪县| 东丰县| 武山县| 峨眉山市| 贵定县| 延吉市| 大宁县| 略阳县| 盐亭县| 巍山| 蕉岭县| 西峡县|