⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 blobtester.java

📁 java网络编程精解 源代码 对网络编程感兴趣的可以一观
💻 JAVA
字号:
import java.sql.*;
import java.io.*;

public class BlobTester{
  Connection con;
  public BlobTester(Connection con){this.con=con;}

  public static void main(String args[])throws Exception{
    Connection con=new ConnectionProvider().getConnection();
    BlobTester tester=new BlobTester(con);  
    tester.createTableWithBlob();
    tester.saveBlobToDatabase();
    tester.getBlobFromDatabase();
    con.close();
  }
  public void createTableWithBlob()throws Exception{
    Statement stmt=con.createStatement();
    stmt.execute("drop table if exists ABLOB");
    stmt.execute("create table ABLOB(ID bigint auto_increment primary key,FILE mediumblob)");
    stmt.close();
  }
  /**向数据库中保存Blob数据 */ 
  public void saveBlobToDatabase()throws Exception{
    PreparedStatement stmt=con.prepareStatement("insert into ABLOB(ID,FILE) values(?,?) ");  
    stmt.setLong(1,1);
    FileInputStream fin=new FileInputStream("test.gif");
    stmt.setBinaryStream(2,fin,fin.available());
    stmt.executeUpdate();
    fin.close();
    stmt.close();
  }
  /** 从数据库中读取Blob数据 */
  public void getBlobFromDatabase()throws Exception{
    Statement stmt=con.createStatement();
    ResultSet rs=stmt.executeQuery("select FILE from ABLOB where ID=1");
    rs.next();
    Blob blob=rs.getBlob(1);
    
    //把数据库中的Blob数据拷贝到test_bak.gif文件中
    InputStream in=blob.getBinaryStream();
    FileOutputStream fout = new FileOutputStream("test_bak.gif");  
    int b=-1;
    while((b=in.read())!=-1)           
      fout.write(b);
    fout.close();
    in.close();
    rs.close();
    stmt.close();
  }
}


/****************************************************
 * 作者:孙卫琴                                     *
 * 来源:<<Java网络编程精解>>                       *
 * 技术支持网址:www.javathinker.org                *
 ***************************************************/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -