c# ORACLE clob读取问题,速度很慢,同事用JAVA很快

cqyyb2000 2018-06-22 05:08:51
主要代码如下:
OracleDataReader reader;
略。。。。
while (reader.Read())
{
// fbyte = (byte[])reader[0];


Oracle.DataAccess.Types.OracleClob clob = reader.GetOracleClob(0);
byte[] blob = new byte[clob.Length];
reader.GetBytes(0, 0, blob, 0,(Int32) blob.Length);



char[] cbuffer = new char[clob.Length];
fbyte = new byte[clob.Length];


while ((actual = clob.Read(cbuffer, 0, cbuffer.Length)) > 0) //在这里读一个6M大小的文件 ,会有1分钟,但同事用JAVA只要13秒
{

i++;
string temps = new string(cbuffer, 0, actual);
base64Str = base64Str + temps;


}
...全文
437 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
cqyyb2000 2018-06-23
  • 打赏
  • 举报
回复
大神帮忙看一下啊
suchvaliant 2018-06-22
  • 打赏
  • 举报
回复
char[] cbuffer = new char[clob.Length];
fbyte = new byte[clob.Length];


while ((actual = clob.Read(cbuffer, 0, cbuffer.Length)) > 0) //在这里读一个6M大小的文件 ,会有1分钟,但同事用JAVA只要13秒
{

i++;
string temps = new string(cbuffer, 0, actual);
base64Str = base64Str + temps;


}
改为:
base64Str += Encoding.Default.GetString(blob);
  • 打赏
  • 举报
回复
嗯,可惜你看不到技术的回复,可能只能要个代码。
cqyyb2000 2018-06-22
  • 打赏
  • 举报
回复
楼上大哥:现在的问题是clob.Read(cbuffer, 0, cbuffer.Length)) 这一段时间会很久
  • 打赏
  • 举报
回复
另外,如果你的第一段读取代码可以,为什么又去读取一遍 clob 呢?
  • 打赏
  • 举报
回复
首先要注意,对于 base64Str ,应该定义为 StringBuilder 而不是 String。
cqyyb2000 2018-06-22
  • 打赏
  • 举报
回复
补充,这段代码基本来源于网上百度,但在实际运行中,效率很差,各位大神看下
本课程详细讲解了以下内容:    1.jsp环境搭建及入门、虚拟路径和虚拟主机、JSP执行流程    2.使用Eclipse快速开发JSP、编码问题、JSP页面元素以及request对象、使用request对象实现注册示例    3.请求方式的编码问题、response、请求转发和重定向、cookie、session执行机制、session共享问题     4.session与cookie问题及application、cookie补充说明及四种范围对象作用域     5.JDBC原理及使用Statement访问数据库、使用JDBC切换数据库以及PreparedStatement的使用、Statement与PreparedStatement的区别     6.JDBC调用存储过程和存储函数、JDBC处理大文本CLOB及二进制BLOB类型数据     7.JSP访问数据库、JavaBean(封装数据和封装业务逻辑)     8.MVC模式与Servlet执行流程、Servlet25与Servlet30的使用、ServletAPI详解与源码分析     9.MVC案例、三层架构详解、乱码问题以及三层代码流程解析、完善Service和Dao、完善View、优化用户体验、优化三层(加入接口和DBUtil)    1 0.Web调试及bug修复、分页SQL(Oracle、MySQL、SQLSERVER)     11.分页业务逻辑层和数据访问层Service、Dao、分页表示层Jsp、Servlet     12.文件上传及注意问题、控制文件上传类型和大小、下载、各浏览器下载乱码问题     13.EL表达式语法、点操作符和中括号操作符、EL运算、隐式对象、JSTL基础及set、out、remove     14.过滤器、过滤器通配符、过滤器链、监听器     15.session绑定解绑、钝化活化     16.以及Ajax的各种应用     17. Idea环境下的Java Web开发

110,566

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧