MySQL存儲文本和圖片的方法
更新時間:2019年03月04日 10:39:44 作者:kerer-sk
今天小編就為大家分享一篇關于MySQL存儲文本和圖片的方法,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
Oracle中大文本數(shù)據(jù)類型
Clob 長文本類型 (MySQL中不支持,使用的是text) Blob 二進制類型
MySQL數(shù)據(jù)庫
Text 長文本類型 TINYTEXT: 256 bytes TEXT: 65,535 bytes => ~64kb MEDIUMTEXT: 16,777,215 bytes => ~16MB LONGTEXT: 4,294,967,295 bytes => ~4GB Blob 二進制類型
例如:
建表
CREATE TABLE test( id INT PRIMARY KEY AUTO_INCREMENT, content LONGTEXT, -- 文本字段 img LONGBLOB -- 圖片字段 );
存儲文本時是以字符類型存儲,存儲圖片時是以二進制類型存儲,具體使用的設置參數(shù)方法,和獲取數(shù)據(jù)方法不同。
例如:
// 存儲文本時
// 存儲時,設置參數(shù)為字符流 FileReader reader
pstmt.setCharacterStream(1, reader);
// 獲取參數(shù)時
// 方式1:
Reader r = rs.getCharacterStream("content");
// 獲取長文本數(shù)據(jù), 方式2:
System.out.print(rs.getString("content"));
// 存儲二進制圖片時
// 設置參數(shù)為2進制流 InputStream in
pstmt.setBinaryStream(1, in);
// 獲取2進制流
InputStream in = rs.getAsciiStream("img");
/**
* 保存照片
*
*/
@Test
public void test2(){
String sql = "insert into test(img) values(?)";
try{
con = JDBCUtil.getConnection();
pstmt = con.prepareStatement(sql);
// 設置參數(shù)
// 獲取文本
File file = new File("f:/a.jpg");
InputStream in = new FileInputStream(file);
// 設置參數(shù)為2進制流
pstmt.setBinaryStream(1, in);
// 執(zhí)行sql
pstmt.executeUpdate();
in.close();
}catch (Exception e) {
e.printStackTrace();
}finally{
try {
JDBCUtil.close(con, pstmt);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
/**
* 獲取照片
*
*/
@Test
public void test3(){
String sql = "select * from test where id=?;";
try{
con = JDBCUtil.getConnection();
pstmt = con.prepareStatement(sql);
// 設置參數(shù)
pstmt.setInt(1, 2);
// 執(zhí)行查詢
rs = pstmt.executeQuery();
while(rs.next()){
byte[] buff = new byte[1024];
InputStream in = rs.getAsciiStream("img");
int l=0;
OutputStream out = new FileOutputStream(new File("f:/1.jpg"));
while((l=in.read(buff))!=-1){
out.write(buff, 0, l);
}
in.close();
out.close();
}
}catch (Exception e) {
e.printStackTrace();
}finally{
try {
JDBCUtil.close(con, pstmt);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
您可能感興趣的文章:
- MySQL實現(xiàn)類似Oracle序列的方案
- mysql實現(xiàn)sequence功能的代碼
- Can''t connect to local MySQL through socket ''/tmp/mysql.sock''解決方法
- Mysql常用函數(shù)大全(分類匯總講解)
- 利用MySQL主從配置實現(xiàn)讀寫分離減輕數(shù)據(jù)庫壓力
- mysql+spring+mybatis實現(xiàn)數(shù)據(jù)庫讀寫分離的代碼配置
- 如何徹底刪除mysql服務(清理注冊表)詳解
- 將圖片儲存在MySQL數(shù)據(jù)庫中的幾種方法
- Ubuntu上mysql的安裝及使用(通用版)
- insert和select結合實現(xiàn)"插入某字段在數(shù)據(jù)庫中的最大值+1"的方法
相關文章
深入了解MySQL中分區(qū)表的原理與企業(yè)級實戰(zhàn)
本文詳細講解什么是分區(qū)表,分區(qū)表增刪改查的工作原理以及分區(qū)表的實戰(zhàn),分區(qū)表的場景有哪些,哪些場景不建議用分區(qū)表,并列舉出六點使用分區(qū)表的誤區(qū),需要的可以參考一下2022-11-11
mysql中inner join和left join使用詳解
本文主要介紹了mysql中inner join和left join使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03
SQL常見函數(shù)整理之Format將日期、時間和數(shù)字值格式化
最近項目總是寫sql查詢時間,數(shù)據(jù)庫存的時間有各種格式,下面這篇文章主要給大家介紹了關于SQL常見函數(shù)整理之Format將日期、時間和數(shù)字值格式化的相關資料,需要的朋友可以參考下2024-01-01
MySQL加減間隔時間函數(shù)DATE_ADD和DATE_SUB的實現(xiàn)
mysql中內置函數(shù)date_add 和 date_sub能對指定的時間進行增加或減少一個指定的時間間隔,本文主要介紹了MySQLDATE_ADD和DATE_SUB的實現(xiàn),感興趣的可以了解一下2024-09-09

