保存圖片到MySQL以及從MySQL讀取圖片全過程
接上次 爬取表情包 ,這次我們直接將表情包存到MySQL數(shù)據(jù)庫而不是本地。
1. 創(chuàng)建數(shù)據(jù)庫
首先創(chuàng)建一個(gè)數(shù)據(jù)庫,數(shù)據(jù)庫名為ikun,表名為img,3個(gè)字段分別為id(圖片id)、img(二進(jìn)制碼)、date(存儲(chǔ)時(shí)間)
其中,二進(jìn)制碼的存儲(chǔ)格式應(yīng)該為 BLOB類型,下面為不同類型對(duì)應(yīng)的最大存儲(chǔ)空間
TINYBLOB
255個(gè)字節(jié)BLOB
65535字節(jié)MEDIUMBLOB
16MLONGBLOB
4G
USE ikun; CREATE TABLE `img` ( `id` int NOT NULL AUTO_INCREMENT, `img` mediumblob NOT NULL, `date` date NOT NULL, PRIMARY KEY (`id`) ) ;
2. 保存圖片到數(shù)據(jù)庫
將圖片轉(zhuǎn)為二進(jìn)制流
對(duì)于圖片的輸入和輸出,我們更多使用BufferedInputStream或者BufferedOutPutStream
public static void saveInMySQL(String url) throws IOException { //獲得連接對(duì)象 Connection con = DBUtil.getConnection("root","******","ikun"); PreparedStatement pre = null; //獲取圖片信息,做輸出流 InputStream in = getEntityByHttpGetMethod(url).getContent(); BufferedInputStream inputStream = new BufferedInputStream(in); try { String sql = "insert into img (img,date) values (?,?)"; pre = con.prepareStatement(sql); pre.setBinaryStream(1,inputStream,in.available()); Date date = new Date(System.currentTimeMillis()); pre.setDate(2,date); //獲取返回結(jié)果 int i = pre.executeUpdate(); System.out.println(i); } catch (SQLException e) { e.printStackTrace(); } }
查看效果
3. 從數(shù)據(jù)庫讀取圖片
將二進(jìn)制流轉(zhuǎn)為文件輸出到本地查看
public static void readFromMysql(){ //獲得連接對(duì)象 Connection con = DBUtil.getConnection("root","******.","ikun"); PreparedStatement pre = null; ResultSet res = null; try { //這里讀取一張 String sql = "select * from img where id = 1"; pre = con.prepareStatement(sql); res = pre.executeQuery(sql); while (res.next()){ int id = res.getInt("id"); InputStream stream = res.getBinaryStream("img"); Date date = res.getDate("date"); System.out.println("圖片id為"+id+" 創(chuàng)建時(shí)間為"+date.toString()); Files.copy(stream, Paths.get("D:\\ikun.jpg")); } } catch (SQLException | IOException e) { e.printStackTrace(); } //斷開連接 DBUtil.close(); }
寫在最后
??通常我們建議不要直接將圖片存到數(shù)據(jù)庫中,而是放到本地磁盤目錄下,我們通常將圖片統(tǒng)一命名,通過其文件名或路徑來訪問數(shù)據(jù)庫實(shí)現(xiàn)獲取圖片的目的。
??而不建議直接往數(shù)據(jù)庫存放圖片的原因如下:
- 數(shù)據(jù)庫性能下降:存儲(chǔ)大量數(shù)據(jù)將占用大量的磁盤空間和系統(tǒng)資源,特別影響數(shù)據(jù)庫性能,尤其是多用戶訪問的情況
- 數(shù)據(jù)庫的備份和維護(hù)變得困難,且可讀性差
- 壓力測(cè)試:多用戶同時(shí)上傳或下載圖片時(shí),將導(dǎo)致數(shù)據(jù)庫服務(wù)器壓力負(fù)載過大
- 圖片質(zhì)量下降:比如我們待會(huì)的運(yùn)行結(jié)果其實(shí)是這樣的,左邊是我們下載到本地的圖片,右邊則是下載到數(shù)據(jù)庫,再從數(shù)據(jù)庫讀取出來的效果。而且我將二進(jìn)制數(shù)值類型設(shè)置為最大還是模糊。
到此這篇關(guān)于保存圖片到MySQL以及從MySQL讀取圖片的文章就介紹到這了,更多相關(guān)保存圖片到MySQL及讀取內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL空間數(shù)據(jù)存儲(chǔ)及函數(shù)
這篇文章主要介紹的使MySQL空間數(shù)據(jù)存儲(chǔ)及函數(shù),MySQL提供了數(shù)據(jù)類型geometry用來存儲(chǔ)坐標(biāo)信息,MySQL為空間數(shù)據(jù)存儲(chǔ)及處理提供了專用的類型geometry,下面就和小編一起學(xué)習(xí)下文吧2021-09-09獲取MySQL的表中每個(gè)userid最后一條記錄的方法
這篇文章主要介紹了獲取MySQL的表中每個(gè)userid最后一條記錄的方法,并且針對(duì)userid不唯一的情況,需要的朋友可以參考下2015-05-05MySQL中聚合函數(shù)count的使用和性能優(yōu)化技巧
這篇文章主要介紹了Windows 10,MySQL版本是5.7.12-log環(huán)境下mysql中聚合函數(shù)count的使用和性能優(yōu)化,需要的朋友可以參考下2018-06-06MySql中now()與sysdate()區(qū)別小結(jié)
本文主要介紹了MySql中now()與sysdate()區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05mysql?子查詢的概述和分類及單行子查詢功能實(shí)現(xiàn)
本文詳細(xì)介紹了MySQL的子查詢概念和應(yīng)用,解釋了子查詢是在主查詢中嵌套另一個(gè)查詢,包括外查詢和內(nèi)查詢,并從多個(gè)角度進(jìn)行分類,文章還深入探討了子查詢的編寫技巧和使用場(chǎng)景,對(duì)于學(xué)習(xí)和應(yīng)用MySQL的人來說,這是一篇非常有價(jià)值的指南2024-10-10MySQL用limit方式實(shí)現(xiàn)分頁的實(shí)例方法
在本篇文章中小編給大家整理了一篇關(guān)于MySQL用limit方式實(shí)現(xiàn)分頁的實(shí)例方法,有需要的朋友們可以參考學(xué)習(xí)下。2020-01-01mysql存儲(chǔ)過程之if語句用法實(shí)例詳解
這篇文章主要介紹了mysql存儲(chǔ)過程之if語句用法,結(jié)合實(shí)例形式詳細(xì)分析了mysql存儲(chǔ)過程中if語句相關(guān)原理、使用技巧與操作注意事項(xiàng),需要的朋友可以參考下2019-12-12