Blob,Text 大文件存入數據庫

  1. 將圖片存儲到數據庫中(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類型實際是個類型系列(TinyBlobBlobMediumBlobLongBlob),除了在存儲的最大信息量上不一樣外,他們是等同的。編碼

     2>MySQL的四種BLOB類型spa

    3>實際使用中根據須要存入的數據大小定義不一樣的BLOB類型。須要注意的是:若是你存儲的文件過大,數據庫的性能會降低不少。code

    4>有4TEXT類型:TINYTEXTTEXTMEDIUMTEXTLONGTEXT。這些對應4BLOB類型,有相同的最大長度和存儲需求 對象

相關文章
相關標籤/搜索