zoukankan      html  css  js  c++  java
  • 图片数据&大文本数据存储

    图片数据的存储(数据库字段格式为blob)  

    存数据  

    Connection conn = JdbcUtils.getConnection();
    //创建预处理对象
    PreparedStatement pstmt = conn.prepareStatement("insert into t1 values(?,?)");
    //指定问号的值
    pstmt.setInt(1, 1);
    File file = new File("src/2.gif");
    InputStream in = new FileInputStream(file);
    pstmt.setBinaryStream(2, in, file.length());
    //执行SQL语句
    pstmt.executeUpdate();

    取数据  

    Connection conn = JdbcUtils.getConnection();
    //创建预处理对象
    PreparedStatement pstmt = conn.prepareStatement("select * from t1");
    //执行SQL语句
    ResultSet rs = pstmt.executeQuery();
    if(rs.next()){
    int id = rs.getInt("id");
    InputStream in = rs.getBinaryStream("image");
    //需要再建一个文件
    File file = new File("src/3.gif");
    OutputStream os = new FileOutputStream(file);
    byte[] buffer = new byte[1024];
    int b = 0;
    while((b=in.read(buffer)) != -1){
    os.write(buffer,0,b);
    }

    大文本数据的存储(数据库字段格式为text)    

    存数据  

    Connection conn = JdbcUtils.getConnection();
    //创建预处理对象
    PreparedStatement pstmt = conn.prepareStatement("insert into t2 values(?,?)");
    //指定问号的值
    pstmt.setInt(1, 1);
    File file = new File("src/a.txt");
    FileReader fileReader = new FileReader(file);
    pstmt.setCharacterStream(2, fileReader,file.length());
    //执行SQL语句
    pstmt.executeUpdate();

    取数据   

    Connection conn = JdbcUtils.getConnection();
    //创建预处理对象
    PreparedStatement pstmt = conn.prepareStatement("select * from t2");
    //执行SQL语句
    ResultSet rs = pstmt.executeQuery();
    if(rs.next()){
    int id = rs.getInt("id");
    Reader reader = rs.getCharacterStream("txt");
    //需要再建一个文件
    File file = new File("src/b.txt");
    BufferedReader br = new BufferedReader(reader);
    BufferedWriter bw = new BufferedWriter(new FileWriter(file));
    String s = "";
    while((s = br.readLine()) != null){
    bw.write(s);
    bw.write("
    ");
    }
    br.close();
    bw.close();
    }

    本文出自 “曾颐楠的播客” 博客,请务必保留此出处http://zengyinan.blog.51cto.com/9524976/1721403

  • 相关阅读:
    matlab基础知识
    reverse number
    C++基础知识(一)
    ES6 let const学习
    [ZZ]一名IT从业者的英语口语能力成长路径
    使用windows Live Writer 以及office word 2013发布文章到博客园总结
    CString.format的用法
    Cstring 与 string 注意点
    卡尔曼滤波应用
    linux 重新挂载分区(教程)
  • 原文地址:https://www.cnblogs.com/zengyinanos/p/5042766.html
Copyright © 2011-2022 走看看