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);
            }
        }
    }
  • 相关阅读:
    坐标变化
    labelme VOC
    threejs物体设置中心坐标
    IfcProjectOrderTypeEnum
    IfcCostItemTypeEnum
    利用Mono.Cecil动态修改程序集来破解商业组件(仅用于研究学习)
    依赖注入框架Autofac的简单使用
    阿里技术嘉年华官网上线啦!
    Silverlight 4以下版本模拟鼠标双击事件
    iOS学习系列 利用ASIHTTPRequest实现异步队列
  • 原文地址:https://www.cnblogs.com/aigeileshei/p/5712349.html
Copyright © 2011-2022 走看看