將圖片存儲到數據庫中(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類型,有相同的最大長度和存儲需求 對象