Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 2282|回复: 0

java将文件保存为二进制流到oracle表中的blob字段

  [复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2013-2-22 22:00:20 | 显示全部楼层 |阅读模式
    有时候,我们需要将文件以二进制流的形式存入数据库中,比如oracle表中有一个字段为files,字段类型为blob。如果编写存储过程,传入blob参数或者文件的路径进行处理似乎有些难度,处理起来也麻烦。由于项目使用到了spring,所以使用springjdbc作新增和更新操作。
    例如:oraclet_customer_health_document表中有名为files,类型为blob的字段,需要保存一张图片。
    首先,创建一个工具类以获取spring的上下文,如下:
    package com.zhangjie.test;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.support.ClassPathXmlApplicationContext;
    public class TaskInit {
    private static ApplicationContext context = null;
    /**
    * 单例 ApplicationContext
    *  用于获取Spring容器中beans
    * @return ApplicationContext
    * @see
    */
    public static ApplicationContext getInstance() {
    if (context == null) {
    context = new ClassPathXmlApplicationContext(new String[] {
    "applicationContext.xml"});
    }
    return context;
    }
    }
    然后,使用jdbc操作来将文件保存到files字段中,如下:
    package com.zhangjie.test;
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import oracle.sql.BLOB;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.jdbc.datasource.DataSourceUtils;
    import org.springframework.jdbc.support.JdbcUtils;
    public class UpdateFiles {
    public static Boolean updateFiles(String id, String filepath) {
    Boolean result = false;
    JdbcTemplate jdbcTemplate = (JdbcTemplate) TaskInit.getInstance()
    .getBean("jdbcTemplate");;
    Connection con = null;
    PreparedStatement pstmt = null;
    ResultSet rset = null;
    try {
    con = DataSourceUtils.getConnection(jdbcTemplate.getDataSource());
    con.setAutoCommit(false);
    BLOB blob = null;
    pstmt = con
    .prepareStatement("update t_customer_health_document set files=empty_blob() where id=?");
    pstmt.setString(1, id);
    pstmt.executeUpdate();
    pstmt.close();
    pstmt = con
    .prepareStatement("select files from t_customer_health_document where id= ? for update");
    pstmt.setString(1, id);
    rset = pstmt.executeQuery();
    if (rset.next())
    blob = (BLOB) rset.getBlob(1);
    File f = new File(filepath);
    FileInputStream fin = new FileInputStream(f);
    pstmt = con
    .prepareStatement("update t_customer_health_document set files=? where id=?");
    OutputStream out = blob.getBinaryOutputStream();
    byte[] data = new byte[(int) fin.available()];
    fin.read(data);
    out.write(data);
    fin.close();
    out.close();
    pstmt.setBlob(1, blob);
    pstmt.setString(2, id);
    pstmt.executeUpdate();
    pstmt.close();
    con.commit();
    con.close();
    result = true;
    } catch (SQLException e) {
    e.printStackTrace();
    } catch (IllegalArgumentException e) {
    e.printStackTrace();
    } catch (IOException e) {
    e.printStackTrace();
    } finally {
    JdbcUtils.closeResultSet(rset);
    JdbcUtils.closeStatement(pstmt);
    DataSourceUtils
    .releaseConnection(con, jdbcTemplate.getDataSource());
    }
    return result;
    }
    public static void main(String[] args) {
    boolean is = updateFiles("D6256CEBFEF76A03E040A8C057E005B3", "D:\\web deployment assembly.jpg");
    System.out.println(is);
    }
    }




    回复

    使用道具 举报

    该用户从未签到

    发表于 2013-2-22 22:00:36 | 显示全部楼层
    谢谢楼主总结的非常好啊。
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 17:50 , Processed in 0.381619 second(s), 47 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表