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);
        }
    }
}

 

JDBC进行批处理:

package cn.itcast.demo5;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;

import org.junit.Test;

import cn.itcast.demo3.JdbcUtils;

/**
 * 批处理
 * @author Administrator
 *
 */
public class Demo5 {
    
    /**
     * pstmt对象内部有集合
     * 1、用循环疯狂向pstmt中添加sql参数,它自己有模板,使用一组参数和模板可以匹配出一条sql语句
     * 2、调用它的执行批方法,完成向数据库发送!
     */
    @Test
    public void fun5() throws SQLException{
        Connection conn=JdbcUtils.getConnection();
        String sql="INSERT INTO t_stu VALUES (?,?,?,?)";
        PreparedStatement pstmt=conn.prepareStatement(sql);
        
        for(int i=0;i<1000;i++){
            pstmt.setInt(1, i+1);
            pstmt.setString(2, "stu_"+i);
            pstmt.setInt(3, i);
            pstmt.setString(4, i%2==0?"男":"女");
            
            pstmt.addBatch();
        }
        
        long start=System.currentTimeMillis();
        pstmt.executeBatch();
        long end=System.currentTimeMillis();
        System.out.println(end - start );
    }
}