Java 存取图片到Sybase image 字段 的问题

pufeng_999 2003-10-24 05:13:08
为什么我只能存取32K的数据,大于32K的数据就不行
建表是这样建的 create table (len int ,data image )
java 代码如下,请指教
<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.sql.*"%>
<%@ page import="java.lang.*"%>
<%@ page import="jbsybtest.DBBean"%>
<%@ page import="jbsybtest.QueryBean"%>
<%@ page import="java.io.*"%>
<%
String getType = "";
System.out.println(pageContext.getRequest().getParameter("Type"));
if (pageContext.getRequest().getParameter("Type")!=null)
{
getType = pageContext.getRequest().getParameter("Type").toString();

if (getType.equals("insert")){
//file size = 69576 这是我指定的一个文件,为了方便
java.io.File file = new java.io.File("C:\\1.jpg");

java.io.FileInputStream fis = new java.io.FileInputStream(file);
System.out.println((int) file.length());

int l = (int) file.length();
Integer intLen = new Integer(l);


ResultSet result = null;
String mSql = null;
PreparedStatement prestmt = null;

DBBean DBLink = new DBBean();
DBLink.openDBConnect();
mSql = "insert into ss (id ,data) values (?,?)";
prestmt = DBLink.getConn().prepareStatement(mSql);
prestmt.setInt(1,1);
prestmt.setBinaryStream (2, fis , l );

DBLink.setAutoCommit(true);
prestmt.executeUpdate();
DBLink.getConn().commit();
} else {
int bytesum=0;
int byteread=0;
ResultSet result=null;
String Sql=null;
PreparedStatement prestmt=null;
DBBean DBLink = new DBBean();
DBLink.openDBConnect();

Sql="select * from dd";
result=DBLink.executeQuery(Sql);
result.next();

java.io.InputStream inStream=result.getBinaryStream("filedata");
java.io.FileOutputStream fs=new java.io.FileOutputStream("c:\\xx.jpg");

byte[] b = new byte[69576];//file size
int i = 0;
final int unitlen = 16384;
int cbread;
int l = b.length;
for ( i =0;i < l; i+=unitLen){
if (l - i < cbread) {
cbread = inStream.read(b,i,l-i);
}else{
cbread = inStream.read(b,i,unitLen);
}
System.out.println(cbread);
}

fs.write(b);
fs.close();
}}

%>
...全文
170 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
pufeng_999 2003-10-24
  • 打赏
  • 举报
回复
哦,数据库名打错了,都是表ss
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

62,622

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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