zoukankan      html  css  js  c++  java
  • JDBC操作简单实用了IOUtils

    package cn.itcast.demo4;
    
    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.sql.Blob;
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    
    import javax.sql.rowset.serial.SerialBlob;
    
    import org.apache.commons.io.IOUtils;
    import org.junit.Test;
    
    import cn.itcast.demo3.JdbcUtils;
    
    /**
     * 大数据
     * @author Administrator
     *
     */
    public class Demo4 {
        
        /**
         * 将mp3保存到数据库中
         */
        @Test
        public void fun1() throws Exception{
            /*
             *得到Connection
             *给出sql模板,创建pstmt
             *设置sql模板中的参数
             *调用pstmt中的executeUpdate()执行 
             */
            Connection con=JdbcUtils.getConnection();
            String sql="INSERT INTO tab_bin VALUES(?,?,?)";
            PreparedStatement pstmt=con.prepareCall(sql);
            
            pstmt.setInt(1, 1);
            pstmt.setString(2, "陈粒-奇妙能力歌.mp3");
            /**
             * 需要得到Blob
             * 我们有文件,目标是Blob
             * 先将文件变成byte[]
             * 再使用byte[]创建Blob
             */
            
            byte[] bytes=IOUtils.toByteArray(new FileInputStream("E:\KuGou\陈粒 - 奇妙能力歌.mp3"));
            Blob blob=new SerialBlob(bytes);
            pstmt.setBlob(3, blob);
            
            pstmt.executeUpdate();
             
        }
        
        @Test
        public void fun2() throws Exception{
            Connection conn=JdbcUtils.getConnection();
            
            String sql="SELECT * FROM tab_bin";
            PreparedStatement pstmt=conn.prepareStatement(sql);
            
            ResultSet rs=pstmt.executeQuery();
            
            if(rs.next()){
                Blob blob=rs.getBlob("resource");
                InputStream in=blob.getBinaryStream();
                OutputStream out=new FileOutputStream("e:/"+rs.getString("bname"));
                IOUtils.copy(in, out);
            }
        }
    }
  • 相关阅读:
    跳跃表原理
    查看Oracle操作历史的试图
    【概念】为什么有时全表扫描比通过索引扫描效率更高
    oracle驱动表以及如何确定驱动表
    SpringBoot学习(三)-----配置Bean
    leetcode 面试题58
    leetcode 1365 有多少小于当前数字的数字
    leetcode 1342 将数字变成 0 的操作次数
    leetcode1313 解压缩编码列表
    leetcode 1071 字符串的最大公因子
  • 原文地址:https://www.cnblogs.com/aigeileshei/p/5712349.html
Copyright © 2011-2022 走看看