你们都是坏人 2012-08-31 11:28 采纳率: 33.3%
浏览 187
已采纳

从oralce中读取blob多图,只显示一张图的问题

[code="java"]<%@ page language="java" pageEncoding="UTF-8" contentType="image/jpeg" import="java.awt.image.*,java.sql.*,com.sun.image.codec.jpeg.*,java.util.*,javax.imageio.*,java.io.*"%>

<%

Connection conn=null;
Statement stmt=null;
ResultSet rs=null;
conn=sql.getConnection();
stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY);  

BufferedInputStream inputimage=null;
boolean defaultCommit = conn.getAutoCommit();
conn.setAutoCommit(false);
try
{
int i=0;
rs = stmt.executeQuery(" SELECT Pic from V_USER WHERE USER='MAX'");

while (rs.next())
{
i++;
oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob("Pic");
inputimage = new BufferedInputStream(blob.getBinaryStream());
}rs.close();
}
catch (Exception ex)
{
System.out.println("blobRead()'s exception"+ex);
conn.rollback();
throw ex;
}
conn.setAutoCommit(defaultCommit);
// Send back image
BufferedImage image = null;
try
{
image = ImageIO.read(inputimage);
}
catch(IOException e)
{
System.out.println(e);
}
ServletOutputStream sos = response.getOutputStream();
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(sos);
encoder.encode(image);
inputimage.close();
%> [/code]

SELECT Pic from V_USER WHERE USER='MAX' 的值有多笔资料,
在页面上显示时,只显示最后一张图,请问是何原因啊!!

  • 写回答

2条回答 默认 最新

  • jinnianshilongnian 2012-08-31 12:57
    关注

    问题1:
    你是通过jsp页面输出图像的,因此一个页面仅能输出一个图片;

    问题2:
    如下语句 将从oracle获取最后一个blob数据给inputimage,因此只输出最后一次的数据
    while (rs.next())

    {

    i++;

    oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob("Pic");

    inputimage = new BufferedInputStream(blob.getBinaryStream());

    }rs.close();

    }

    解决方案:

    1、在要显示图片的网页使用:
    for 图片id 图片idList {

    }

    2、请求JSP时带上图片的id
    如?id=123

    3、jsp根据id查一个图片写出

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算