通过OracleDataReader来读取BLOB类型的数据 (转载)

 通过OracleDataReader来读取BLOB类型的数据 

    在实际的应用过程中,需要把大块的二进制数据存储在数据库中。读取这些大块的数据,可以通过强制类型转换成为byte数组,但是当这个二进制数据体够大时(几十兆或者上百兆),一次并不能获取到他的完整长度,所以需要分块获取。
    下面提供两种方法,供大家参考。
    1、直接将BLOB数据转换成为byte数组
   

          long blobDataSize = 0//BLOB数据体实际大小
                long readStartByte = 0;//从BLOB数据体的何处开始读取数据
                int bufferStartByte = 0;//将数据从buffer数组的何处开始写入
                int hopeReadSize = 1024//希望每次从BLOB数据体中读取数据的大小
                long realReadSize = 0;//每次实际从BLOB数据体中读取数据的大小
                
//CommandBehavior.SequentialAccess将使OracleDataReader以流的方式加载BLOB数据
                OracleDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
                
byte[] buffer = null;
                
while (dr.Read())
                
{
                    blobDataSize 
= dr.GetBytes(00null00); //获取这个BLOB数据体的总大小
                    buffer = new byte[blobDataSize];
                    realReadSize 
= dr.GetBytes(0, readStartByte, buffer, bufferStartByte, hopeReadSize);
                    
//循环,每次读取1024byte大小
                    while ((int)realReadSize == hopeReadSize)
                    
{
                        bufferStartByte 
+= hopeReadSize;
                        readStartByte 
+= realReadSize;
                        realReadSize
= dr.GetBytes(0, readStartByte, buffer, bufferStartByte, hopeReadSize);
                    }

                    
//读取BLOB数据体最后剩余的小于1024byte大小的数据
                    dr.GetBytes(0, readStartByte, buffer, bufferStartByte, (int)realReadSize);
                    
//读取完成后,BLOB数据体的二进制数据就转换到这个byte数组buffer上去了
                }

   
    2、将BLOB数据直接写到文件中去
   

         
                
long readStartByte = 0;//从BLOB数据体的何处开始读取数据
                int hopeReadSize = 1024//希望每次从BLOB数据体中读取数据的大小
                long realReadSize = 0;//每次实际从BLOB数据体中读取数据的大小
                
//CommandBehavior.SequentialAccess将使OracleDataReader以流的方式加载BLOB数据
                OracleDataReader dr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);
                
while (dr.Read())
                {
                    FileStream fs 
= new FileStream(filename, FileMode.Create);
                    
byte[] buffer = new byte[hopeReadSize];
                    realReadSize 
= dr.GetBytes(0, readStartByte, buffer, 0, hopeReadSize);
                    
//循环,每次读取1024byte大小,并将这些字节写入流中
                    while ((int)realReadSize == hopeReadSize)
                    {
                        fs.Write(buffer, 
0, hopeReadSize);
                        readStartByte 
+= realReadSize;
                        realReadSize
= dr.GetBytes(0, readStartByte, buffer, 0, hopeReadSize);
                    }
                    
//读取BLOB数据体最后剩余的小于1024byte大小的数据,并将这些字节写入流中
                    realReadSize= dr.GetBytes(0, readStartByte, buffer, 0, hopeReadSize);
                    fs.Write(buffer, 
0, (int)realReadSize);
                }

 

转载自:http://blog.csdn.net/lonet/archive/2010/03/03/5342386.aspx

转载于:https://www.cnblogs.com/wuhenke/archive/2010/10/25/1860752.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/380848.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PHP简介

PHP原始为Personal Home Page的缩写,已经正式更名为 “PHP: Hypertext Preprocessor”。PHP即“超文本预处理器”,是一种通用开源脚本语言。PHP是在服务器端执行的脚本语言,与C语言类似,是常用的网站编程语言。PHP独特的语法混合了…

java 事务_Java中事务总结详解(精华)

1.什么是JAVA事务?通常的观念认为,事务仅与数据库相关。事务必须服从ISO/IEC所制定的ACID原则。ACID是原子性(atomicity)、一致性(consistency)、隔离性 (isolation)和持久性(durability)的缩写。事务的原子性:表示事务执行过程中的任何失败都…

ellen 纽奥良大学演讲

英 文 中 文 Thank you, President Cowan, Mrs. President Cowen; distinguished guests, undistinguished guests - you know who you are, honored faculty and creepy Spanish teacher. And thank you to all the graduating class of 2009, I realize most of you are hu…

xampp启动Apache端口被占用,修改端口

apache启动端口被占用有可能是80端口被占用,也用可能是443端口被占用。修改这两个端口方法如下: 首先打开xampp,点击下图的config 如果是80端口被占用,选择httpd,conf,会自动打开这个文件,然后在文件里查找80 找到以…

java怎么获取当前日期_JAVA中获取当前系统时间

一. 获取当前系统时间和日期并格式化输出:import java.util.Date;import java.text.SimpleDateFormat;public class NowString {public static void main(String[] args) {SimpleDateFormat df new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式System.o…

Microsoft SharePoint Server 2010 的新增功能

Microsoft SharePoint Server 2010 包括几个关键的增强和新增功能。重新设计的用户界面中的功能区通过将命令放置到更易于导航的基于任务的选项卡上,来帮助您更快地完成工作。可以跨多个 Internet 浏览器工作,例如 Microsoft Internet Explorer 7.0 和 8…

php四种定界符

1.标准风格 <?php//代码 ?>2.短标记风格 <?//代码 ?>默认情况下是不可以这样写的&#xff0c;我们要到php.ini文件里修改一个配置 找到php.ini文件,我用的是xampp,所以就是以他为例&#xff0c;其他找到php.ini文件方法百度一下就知道了 点击Apache的config&…

周易Java_周易API接口_免费数据接口 - 极速数据

package api.jisuapi.zhouyi;import java.net.URLEncoder;import api.util.HttpUtil;import net.sf.json.JSONArray;import net.sf.json.JSONObject;public class Search {public static final String APPKEY "your_appkey_here";// 你的appkeypublic static final …

SharePoint SiteCollection 和SubWeb之间的迁移

因为各种不同的原因&#xff0c;项目里可能碰到需要将一个Site Collection迁移为一个子站点的情况。 实现这种需求只能用 内容部署功能中的导出和导入〉 SiteCollectoin to sub web 示例&#xff1a; cd C:\Program Files\Common Files\Microsoft Shared\web server extensions…

php中文乱码问题

访问我的php文件&#xff0c;出现了乱码 解决方法如下&#xff1a; 方法1&#xff1a;加上meta标签&#xff0c;设置字符格式 例如&#xff1a; <?phpecho <meta charset"utf-8">;echo "小河流水人家"; ?>访问就不会乱码了&#xff0c;注…

java 文件转换字符串_java字符串文件互相转换

Java字符串与文件的互转Java中有时候需要读取一个文本类的文件,将其转换为字符串&#xff0c;然后做进一步处理。Java中没有现成的API方法&#xff0c;自己手动实现一个&#xff0c;大家来分享。一、字符串转换为文件/*** 将字符串写入指定文件(当指定的父路径中文件夹不存在时…

使用SQL SERVER 2000的全文检索功能

< DOCTYPE html PUBLIC -WCDTD XHTML StrictEN httpwwwworgTRxhtmlDTDxhtml-strictdtd> 使用SQL SERVER 2000的全文检索功能 步骤&#xff1a; 1、 打开NorthWind数据库&#xff0c;右键Products表&#xff0c;选择“全文索引表”&#xff0c;“在表上定义全文索引”&…

php中的echo、print,print_r、var_dump

我们用代码的运行结果来说明 1、echo <?phpheader(content-type:text/html;charsetutf-8);echo "小河流水人家",<br>;echo 10,<br>;echo true,<br>;echo false,<br>;echo array(8),<br>; ?>运行结果 可以输出字符串和数字…

js数字最多保留两位小数_8085微处理器中最多两个8位数字

js数字最多保留两位小数Problem statement: 问题陈述&#xff1a; To find maximum of two 8bit numberusing 8085 microprocessor. 使用8085微处理器查找最多两个8位数字。 Algorithm: 算法&#xff1a; Load the accumulator with the first data. 向累加器加载第一个数据…

风雨20年:我所积累的20条编程经验 (转)

风雨20年&#xff1a;我所积累的20条编程经验 (转) 编者按&#xff1a;原文作者乔纳森丹尼可&#xff08;Jonathan Danylko&#xff09;是一位自由职业的web架构师和程序员&#xff0c;编程经验已超过20年&#xff0c;涉足领域有电子商务、生物技术、房地产、医疗、保险和公用事…

php的变量、传值、传址、销毁变量

在php中&#xff0c;php的语句需要以**;**结尾&#xff0c;而且变量区分大小写&#xff0c;但关键字不区分大小写 1、变量的命名规则 变量必须以$开头&#xff0c;比如$name&#xff0c;$不是变量名的一部分&#xff0c;仅表示变量名的开始除了$以外&#xff0c;以字母、下划…

java项目 建文件夹_java创建文件夹

用java建立文件夹package test;public class muluTest{public static void main(String[] args){muluTest mulutest new muluTest();mulutest.newFolder("D:\\abcds");}public void newFolder(String folderPath){String filePath folderPath;filePath …

stl vector 函数_vector :: push_back()函数,以及C ++ STL中的示例

stl vector 函数C vector :: push_back()函数 (C vector::push_back() function) vector::push_back() is a library function of "vector" header, it is used to insert/add an element at the end of the vector, it accepts an element of the same type and ad…

Virtools自己编译播放器

virtools可以自己是一sdk来编写播放器&#xff0c;在安装目录的sdk下有一个CustomPlayer的例子。位于StandalonePlayer目录下。 改例子包含了一个readme.txt文件来描述如何使用CustomPlayer.exe。 运行是会出现一个提示框&#xff0c;可以把CustomPlayerApp.cpp中的_Publishing…

php的超全局变量

php的超全局变量如下图 所有的超全局变量都是数组类型&#xff0c;并且php已经帮我们定义好了&#xff0c;下面重点介绍几个 $_GET:用来保存get方式提交的数据 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title>测试$_GET…