mysql,sqlserver,oracle三种数据库的大对象存取(3)

来源:未知 责任编辑:责任编辑 发表时间:2014-03-23 22:31 点击:

        FileOutputStream out = new FileOutputStream("d:/bbb.exe");
        byte[] b = new byte[1024];
        int len = 0;
        while ( (len = in.read(b)) != -1) {
          out.write(b, 0, len);
          out.flush();
        }
        out.close();
        in.close();
        rs.close();
        ps.close();
      }
    }
    catch (Exception ex) {
      ex.printStackTrace(System.out);
    }
    finally {
      try {conn.close();}
      catch (Exception ex) { }
    }
  }
}
 
 
 
ORACLE的大对象存储有些变态,要无论是Blob,还是CLOB都要求先插入一个空值,然后
查询并锁定这一条记录,获取对Lob的引用再进行填充,网上有太多的例子.我个人认为
这种方法垃圾得连写都不想写了,你可以自己去搜索一下.
这种特别的操作既增加操作的复杂度,又违反了JDBC接口的规范,所以我极力反对这样
使用,如果你和我有同样的观点.那么我提供另一种通用的方法.就是你不用LOB而用
oracle的LONG RAW来代替它们.这样就可以象其它对象一样操作了:
 
create table tb_file(filename varchar2(255),filecontent LONG RAW);
 
 
import java.sql.*;
import java.io.*;
 
public class BlobTest {
 
  static String driver = "oracle.jdbc.driver.OracleDriver";
  static String url = "jdbc:oracle:thin:@localhost:1521:test";
  static String user = "system";
  static String passwd = "passwd";
  public static void main(String[] args) throws Exception {
    Connection conn = null;
    try {
      Class.forName(driver);
      conn = DriverManager.getConnection(url, user, passwd);
      int op = 1;
      //插入
      if (op == 0) {
        PreparedStatement ps = conn.prepareStatement("insert into tb_file values (?,?)");
        ps.setString(1, "aaa.exe");
        InputStream in = new FileInputStream("d:/aaa.exe");
        ps.setBinaryStream(2,in,in.available());
        ps.executeUpdate();
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • mysql-mmm
  • mysqldump命令——MySQL数据库备份还原
  • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
  • 简简单单储存过程——循环一个select结果集
  • MySQL数据库十大优化技巧
  • Mysql安装笔记
  • Mysql主主复制架构配置
  • Mysql的Procedure 参数为NULL问题分析
  • MySQL Stmt预处理提高效率问题的小研究
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1