zoukankan      html  css  js  c++  java
  • JDBC中级篇(MYSQL)——处理文件(BLOB)

    微笑注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接:

    package b_blob_clob;
    
    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.io.InputStream;
    import java.sql.Blob;
    import java.sql.Connection;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    
    import util.JdbcUtil;
    /**
     * 关于BLOB:文件
     * 
     * @author mzy
     *
     */
    public class Demo02 {
    	public static void main(String[] args) {
    		// write();
    		
    		/**
    		 * 读取
    		 */
    		Connection conn = null;
    		PreparedStatement stmt = null;
    		ResultSet rs = null;
    		try{
    			conn = JdbcUtil.getConnection();
    			String sql = "select * from news where id=?";
    			stmt = conn.prepareStatement(sql);
    			stmt.setInt(1, 1);
    			rs = stmt.executeQuery();
    			
    			while(rs.next()){
    			
    				//读取blob字段
    				Blob blob = rs.getBlob("attachments");
    				//通过blob字段获取输入字节流
    				InputStream in = blob.getBinaryStream();
    				
    				//把输入字节流写出文件中
    				FileOutputStream out = new FileOutputStream("e:/srceen.exe");
    				byte[] buf = new byte[1024];
    				int len = 0;
    				//边读边写
    				while( (len=in.read(buf))!=-1  ){
    					out.write(buf, 0, len);
    				}  
    				//关闭流
    				out.close();
    				in.close();
    			}
    			
    		}catch(Exception e){
    			e.printStackTrace();
    		}finally{
    			JdbcUtil.close(stmt, conn);
    		}
    	}
    
    	private static void write() {
    		/**
    		 * 写入
    		 */
    		Connection conn = null;
    		PreparedStatement stmt = null;
    		try{
    			conn = JdbcUtil.getConnection();
    			String sql = "update news set attachments=? where id=?";
    			//预编译
    			stmt = conn.prepareStatement(sql);
    			//参数赋值
    			/**
    			 * 读取本地字节文件
    			 * 注意:
    			 * 	1)发送的数据内容超过了字段的长度限制,则抛出 Data too long...异常,这时需要修改字段的类型
    			 *  2)发送的数据内容超过了1MB(mysql服务器默认的接收数据包的大小),可以到mysql安装目录下的my.ini文件添加一个变量max_allowed_packet=50M即可!
    			 */
    			// InputStream in = new FileInputStream("./src/4.jpg"); // 图片大小小于65KB的时候
    			// Data too long for column 'attachments'
    			// InputStream in = new FileInputStream("./src/6.jpg"); // 图片大小大于65KB
    			// 修改attachments:字段的类型从BLOB到mediumBLOB:限制大小为16MB,再大就只能使用LongBLOB了 4GB
    			// InputStream in = new FileInputStream("./src/6.jpg"); // 成功
    			
    			// 上传大小大于1MB的
    			InputStream in = new FileInputStream("./src/InletexEMC.exe");
    			// 这里直接添加成功,如果没有成功需要去mysql的my.ini中配置
    			// max_allowed_packet=随意大小
    			/**
    			 * 设置blob字段
    			 */
    			stmt.setBlob(1, in);
    			stmt.setInt(2, 1);
    			//执行
    			stmt.executeUpdate();
    			System.out.println("添加成功");
    		}catch(Exception e){
    			e.printStackTrace();
    		}finally{
    			JdbcUtil.close(stmt, conn);
    		}
    	}
    }
    


  • 相关阅读:
    cli create ssl certkey
    开启HSTS让浏览器强制跳转HTTPS访问
    Down State Flush Feature
    tasklist、taskkill命令使用
    findstr 命令使用
    【批处理学习笔记】第十一课:常用DOS命令(1)
    【批处理学习笔记】第十课:批处理符号(3)
    【批处理学习笔记】第九课:批处理符号(2)
    【批处理学习笔记】第八课:批处理符号(1)
    【批处理学习笔记】第七课:简单的批处理命令(6)
  • 原文地址:https://www.cnblogs.com/mzywucai/p/11053475.html
Copyright © 2011-2022 走看看