JDBC——BLOB 数据的插入与读取

/**
  * 插入 Blob 类型的数据必须使用 PreparedStatement,因为 BLOB 类型
  * 的数据是无法使用字符串拼写的。
  *
  * 调用 setBlob(int index, InputStream inputStream)
  */
 @Test
 public void testInsertBlob() {
  Connection connection = null;
  PreparedStatement preparedStatement = null;
  try {
   connection = JDBCTools.GetConnection();
   String sql = "INSERT INTO mytable(name, email, hiredate, picture)"
     + "VALUES(?, ?, ?, ?)";
   preparedStatement = connection.prepareStatement(sql);
   preparedStatement.setString(1, "MyDream");
   preparedStatement.setString(2, "MyDream@jdbc.com");
   preparedStatement.setDate(3,
     new Date(new java.util.Date().getTime()));
   InputStream inputStream = new FileInputStream("picture.jpg");
   preparedStatement.setBlob(4, inputStream);
   
   preparedStatement.executeUpdate();

  } catch (Exception e) {

   e.printStackTrace();
  } finally {
   JDBCTools.release(null, preparedStatement, connection);
  }
 }

 

/**
  *  读取 BLOB数据:
  *  1.使用 getBlob 方法读取到 Blob 对象
  *  2.调用 Blob 的 getBinaryStream()方法得到输入流,再使用 IO 操作即可。
  */
 @Test
 public void readBlog(){
  Connection connection = null;
  PreparedStatement preparedStatement = null;
  ResultSet resultSet = null;
  try {
   connection = JDBCTools.GetConnection();
   String sql = "SELECT id, name, email, hiredate, picture"
   + " FROM mytable WHERE id = 6";
   preparedStatement = connection.prepareStatement(sql);
   resultSet = preparedStatement.executeQuery();
   
   if(resultSet.next()){
    int id = resultSet.getInt(1);
    String name = resultSet.getString(2);
    String email = resultSet.getString(3);
    
    System.out.println(id + ", " + name + ", " + email);
   }
   Blob picture = resultSet.getBlob(5);
   
   InputStream in = picture.getBinaryStream();
   OutputStream out = new FileOutputStream("table.jpg");
   byte [] buffer = new byte[1024];
   int len = 0;
   while((len = in.read(buffer)) != -1 ){
    out.write(buffer, 0, len);
   }
   
   out.close();
   in.close();
  } catch (Exception e) {
   e.printStackTrace();
  } finally{
   JDBCTools.release(resultSet, preparedStatement, connection);
  }
 }

转载于:https://my.oschina.net/u/2260265/blog/348577

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值