将图片存储到数据库中(Blob)
java
public void BlogIn(){ Connection con=getConnection(); System.out.println(con); //插入数据库的语句 String sql="insert into user(name,message) values(?,?)"; try { PreparedStatement pstmt= con.prepareStatement(sql); pstmt.setString(1, "ligen"); //读取图片等二进制的文件,使用InputStream输入流 InputStream in=new FileInputStream("G:\\111.jpg"); /* mysql实现了全部方法,但有些方法执行没法经过,没有真正的实现 pstmt.setBlob(2, in); pstmt.setBinaryStream(2, in); */ pstmt.setBinaryStream(2, in, in.available()); pstmt.executeUpdate(); con.close(); } catch (SQLException e) { // TODO Auto-generated catch block
2.将图片从数据库中读出来(Blob)mysql
public void BlogOut(){ Connection con=getConnection(); System.out.println(con); //读取数据库中的语句 String sql="select * from user where id=3"; try { Statement sta= con.createStatement(); ResultSet rs= sta.executeQuery(sql); if(rs.next()){ //经过resultset来获取Blob类型的数据 Blob blog=rs.getBlob("message"); //从数据库中获取此对象并将其转化为输入流对象,以此从数据库中取出 InputStream in= blog.getBinaryStream(); String path="G:\\222.jpg"; OutputStream os=new FileOutputStream(path); //为字节流设置缓冲区 byte[] b=new byte[1024]; int length=0; while((length=in.read(b))!=-1){
3.将大文本类型存入数据库中(Text)sql
public void TextIn(){ Connection con=getConnection(); String sql="insert into user(name,lword) values(?,?)"; try { PreparedStatement ps= con.prepareStatement(sql); ps.setString(1, "text2"); String path="G:\\111.txt"; InputStream in=new FileInputStream(path); /* ps.setBinaryStream(2, in, in.available()); */ //设置链接数据库的流,参数中给的是Reader类型,所以必须新建Reader类的子类 //Reader reader=new InputStreamReader(in, "utf-8"); //ps.setCharacterStream(2, reader,in.available()); //也能够存入数据库,可是乱码,所以存入以前必须设置编码格式 //文本文档之类的采用字符流 Reader reader=new InputStreamReader(in, "utf8"); ps.setCharacterStream(2, reader, in.available()); ps.executeUpdate();
4.将大型文件从数据库中读取出来(Text)数据库
public void TextOut(){ Connection con=getConnection(); String sql="select * from user where id=5"; try { PreparedStatement ps= con.prepareStatement(sql); //ps.setBinaryStream(parameterIndex, x, length) ResultSet rs= ps.executeQuery(sql); if(rs.next()){ Reader reader= rs.getCharacterStream("lword"); BufferedReader buffer=new BufferedReader(reader); /* Writer writer=new OutputStreamWriter(os, "utf-8"); char[] buffer=new char[1024]; int len=0; while((len=reader.read(buffer))!=0){ } */ OutputStream os=new FileOutputStream("G:\\222.txt");
5.Blob与Text性能
1>MySQL中,BLOB是一个二进制大型对象,是一个能够存储大量数据的容器,它能容纳不一样大小的数据。BLOB类型实际是个类型系列(TinyBlob、Blob、MediumBlob和LongBlob),除了在存储的最大信息量上不一样外,他们是等同的。编码
2>MySQL的四种BLOB类型spa
3>实际使用中根据须要存入的数据大小定义不一样的BLOB类型。须要注意的是:若是你存储的文件过大,数据库的性能会降低不少。code
4>有4种TEXT类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。这些对应4种BLOB类型,有相同的最大长度和存储需求 对象