流写入DB

import java.sql.*;
import java.io.*;

/**
 *
 * @author Administrator
 *
 */

public class JpgAndOracle {
// Create.java
 public void Create(String a){
  
 try {
  Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
  String URL="jdbc:oracle:thin:@localhost:1521:gatest";
  String user="water";
  String password="water";
  
  Connection con = DriverManager.getConnection(URL,user,password);
  Statement st = con.createStatement();

  st.execute("CREATE TABLE mytable(id varchar2(10) null, picname varchar2(50) null, pic BLOB null);");
  st.close();
  con.close();
   } catch(Exception e) {
    e.printStackTrace();
   }

 }

 public void SavePic(String a) {
 
   Connection con;    
   PreparedStatement st;
   try {
  Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
  String URL="jdbc:oracle:thin:@localhost:1521:gatest";
  String user="water";
  String password="water";
  con = DriverManager.getConnection(URL,user,password);  
     String sql = "INSERT INTO mytable(id,picname, pic) values('1','mmpic',?)";
    st = con.prepareStatement(sql);
    File f = new File("d://mmpic.jpg");
    FileInputStream fis = new FileInputStream(f);
    st.setBinaryStream(1, fis, (int)f.length());
    st.executeUpdate();
    st.close();
    con.close();
   } catch(Exception e) {
    e.printStackTrace();
   }
 
 }

// ReadPic.java   从数据库中读出图片存成文件
 public void ReadPic(String a) {

   Connection con;
   Statement st;
  
   try {
    Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
    String URL="jdbc:oracle:thin:@localhost:1521:gatest";
    String user="water";
    String password="water";
    con = DriverManager.getConnection(URL,user,password);  
    String sql = "SELECT pic FROM mytable WHERE id='1'";
    st = con.createStatement();
    ResultSet rs = st.executeQuery(sql);
    rs.next();
    File f = new File("C://b.jpg");
    FileOutputStream fos = new FileOutputStream(f);
    InputStream is = rs.getBinaryStream("pic");
    int c;
    byte b[] = new byte[4*1024];
    while ((c=is.read(b))!=-1) {
     fos.write(b, 0, c);
    }
    fos.flush();
    is.close();
    st.close();
    con.close();
   } catch(Exception e) {
    e.printStackTrace();
   }
 }
 
 public static void main(String[] args) throws IOException {
        int sw = 3;    
        JpgAndOracle test = new JpgAndOracle();          
        switch (sw) {
        case 1: // 建表
        {
            test.Create("a");
            break;
        }
        case 2: // 读图片插入数据库
        {
         test.SavePic("b");
            break;
        }
        case 3: // 读出图片行成文件
        {
         test.ReadPic("c");
            break;
        }
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值