jdbc将图片(二进制文件如电影,音乐等)插入数据库

package chap06.sec01;


import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.sql.Clob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;


import model.Book;
import util.DbUtil;


public class Demo2 {
private static DbUtil dbUtil=new DbUtil();
private static int addBook(Book book) throws SQLException, FileNotFoundException{//插入图书

String sql="insert into t_book values(null,?,?,?,?,?,?)"; 
Connection con= dbUtil.getCon();
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, book.getBookName());
pstmt.setFloat(2, book.getPrice());
pstmt.setString(3, book.getAuthor());
pstmt.setInt(4, book.getBookTypeId());
File context=book.getContext();
InputStream in=new FileInputStream(context);
pstmt.setAsciiStream(5, in,context.length());//给第5个坑设置值
File pic=book.getPic();//获得图片文件
InputStream in_pic=new FileInputStream(pic);//将图片文件放入输入流
pstmt.setBinaryStream(6, in_pic, pic.length());//给第6个坑设置值

int result=pstmt.executeUpdate();
dbUtil.closeCon(pstmt, con);
return result;
}

public static void getBook(int id) throws SQLException{
Connection conn=dbUtil.getCon();
String sql="select * from t_book where id=?";
PreparedStatement pre=conn.prepareStatement(sql);
pre.setInt(1, id);
ResultSet rs=pre.executeQuery();
if(rs.next()){
String bookName=rs.getString("bookName");
float price=rs.getFloat("price");
String author=rs.getString("author");
int bookTypeId=rs.getInt("bookTypeId");
Clob c=rs.getClob("context");
String context=c.getSubString(1, (int) c.length());
System.out.println("图书名称:"+bookName);
System.out.println("图书价格:"+price);
System.out.println("图书作者:"+author);
System.out.println("图书类型ID:"+bookTypeId);
System.out.println("图书内容:"+context);
}
dbUtil.closeCon(pre, conn);
}


public static void main(String[] args) throws Exception {
File context=new File("C:/helloworld.txt"); 
File pic=new File("C:/ok.png"); //定义图片,用图片位置创建图片对象
Book book=new Book("javaqwe4",444,"李四4",4,context, pic);
try {
int result =addBook(book);
if(result==1){
System.out.println("添加成功");
}
else{
System.out.println("添加失败");
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("hellowold");
//getBook(15);
}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值