JDBC大数据存取


//大数据存取,程序一般不把大文本或二进制数据保存到数据库;
//大数据分为clob 用于存储文本; blob 用于存储 二进制数据,如图像,声音, 二进制文件。
// Mysql 没有clob,只有TEXT;


1. 封装连接数据工具类


2 大数据存取

import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.Reader;
import java.io.Writer;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import org.junit.Test;


public class CloabDemo {
 @Test
 public void add(){
  Connection conn = null;
  PreparedStatement pstmt = null;
 
  try {
   conn = JdbcUtil.getConnection();//
   String sql = "insert into t1(id,content) values(?,?) ";
   pstmt = JdbcUtil.prepare(conn, sql);
    pstmt.setInt(1, 1);
    //大数据 要使用流的形式
    File file = new File("d:/clob.txt");
    Reader reader = new FileReader(file);
    pstmt.setCharacterStream(2, reader, (int)file.length()); //不能使用long的参数, mysql支持不到那么大的数据
    int i =pstmt.executeUpdate();
    if(i>0){
     System.out.println("插入成功");
    }
   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   finally{
    JdbcUtil.closeConn(conn, pstmt, null);
   }
 }
 //读
 @Test
 public void read(){
  
  Connection conn = null;
  PreparedStatement pstmt = null;
  ResultSet rs = null;
 
  try {
   conn = JdbcUtil.getConnection();//
   String sql = "select * from t1 where id =?";
   pstmt = conn.prepareStatement(sql);
    pstmt.setInt(1, 1);
    //大数据 要使用流的形式
    //保存到E盘
    rs=pstmt.executeQuery(sql);
    if(rs.next()){
    
     Reader reader = rs.getCharacterStream("content");
     Writer writer = new FileWriter("E:/clob.txt");
     char[] c = new char[1024];
     int len =-1;
     while ((len=reader.read(c))!=-1){
      writer.write(c, 0, len);
     }
     reader.close();
     writer.close();
    }
   } catch (Exception e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }
   finally{
    JdbcUtil.closeConn(conn, pstmt, null);
   }
  
 }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值