• 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);
            }
        }
    }
  • 相关阅读:
    伪静态规则写法RewriteRule-htaccess详细语法使用
    事务的操作
    layer 模版使用
    追加下拉框的自动生成
    PHP自动生成前端的表单框架
    MySQL高效获取记录总数
    引用JS表单验证大全 以后方便查看用
    关于left join连接查询 两张表里有同名字段的问题
    详解clientHeight、offsetHeight、scrollHeight
    php防止SQL注入详解及防范
  • 原文地址:https://www.cnblogs.com/aigeileshei/p/5712349.html
Copyright © 2020-2023  润新知