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

 

posted @ 2016-07-27 19:37  guodaxia  阅读(383)  评论(0编辑  收藏  举报