亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL存儲文本和圖片的方法

 更新時間:2019年03月04日 10:39:44   作者:kerer-sk  
今天小編就為大家分享一篇關(guān)于MySQL存儲文本和圖片的方法,小編覺得內(nèi)容挺不錯的,現(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ù)方法,和獲取數(shù)據(jù)方法不同。

例如:

// 存儲文本時
// 存儲時,設(shè)置參數(shù)為字符流 FileReader reader
pstmt.setCharacterStream(1, reader);
// 獲取參數(shù)時
// 方式1:
Reader r = rs.getCharacterStream("content");
// 獲取長文本數(shù)據(jù), 方式2:
System.out.print(rs.getString("content"));
// 存儲二進制圖片時 
// 設(shè)置參數(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è)置參數(shù)
    // 獲取文本
    File file = new File("f:/a.jpg");
    InputStream in = new FileInputStream(file);
    // 設(shè)置參數(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è)置參數(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();
    }
  }
}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • MySQL實現(xiàn)樂觀鎖的方式詳解

    MySQL實現(xiàn)樂觀鎖的方式詳解

    在 MySQL 中,可以通過使用樂觀鎖來實現(xiàn)并發(fā)控制,以避免數(shù)據(jù)沖突和并發(fā)更新問題,樂觀鎖是一種樂觀的思想,它假設(shè)并發(fā)操作不會導(dǎo)致沖突,只有在提交更新時才會檢查是否發(fā)生沖突,本文給大家介紹了Mysql如何實現(xiàn)樂觀鎖,需要的朋友可以參考下
    2023-09-09
  • MySQL slow_log表無法修改成innodb引擎詳解

    MySQL slow_log表無法修改成innodb引擎詳解

    這篇文章主要給大家介紹了關(guān)于MySQL slow_log表無法修改成innodb引擎的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • mysql 5.7.18 安裝教程及問題匯總

    mysql 5.7.18 安裝教程及問題匯總

    這篇文章主要介紹了mysql 5.7.18 安裝教程及問題匯總,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-04-04
  • navicat中創(chuàng)建存儲過程、觸發(fā)器和使用游標的簡單實例(圖文)

    navicat中創(chuàng)建存儲過程、觸發(fā)器和使用游標的簡單實例(圖文)

    這篇文章主要介紹了navicat中創(chuàng)建存儲過程、觸發(fā)器和使用游標的簡單實例,需要的朋友可以參考下
    2017-02-02
  • MySQL關(guān)聯(lián)查詢優(yōu)化實現(xiàn)方法詳解

    MySQL關(guān)聯(lián)查詢優(yōu)化實現(xiàn)方法詳解

    在數(shù)據(jù)庫的設(shè)計中, 我們通常都是會有很多張表 , 通過表與表之間的關(guān)系建立我們想要的數(shù)據(jù)關(guān)系, 所以在多張表的前提下, 多表的關(guān)聯(lián)查詢就尤為重要,這篇文章主要介紹了MySQL關(guān)聯(lián)查詢優(yōu)化
    2022-11-11
  • Windows下Mysql啟動報1067的解決方法

    Windows下Mysql啟動報1067的解決方法

    這篇文章主要為大家詳細介紹了Windows下Mysql啟動報1067的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 一文說透什么是MySQL的預(yù)編譯

    一文說透什么是MySQL的預(yù)編譯

    這篇文章主要介紹了一文說透什么是MySQL的預(yù)編譯,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • MySQL函數(shù)CONCAT、CONCAT_WS、GROUP_CONCAT用法詳解

    MySQL函數(shù)CONCAT、CONCAT_WS、GROUP_CONCAT用法詳解

    這篇文章主要介紹了MySQL函數(shù)CONCAT、CONCAT_WS、GROUP_CONCAT用法詳解,CONCAT 函數(shù)用于將兩個字符串連接為一個字符串,本文通過實例代碼詳細講解,需要的朋友可以參考下
    2023-02-02
  • MySQL?移動數(shù)據(jù)目錄后啟動失敗問題解決

    MySQL?移動數(shù)據(jù)目錄后啟動失敗問題解決

    由于安裝數(shù)據(jù)庫時將MySQL的數(shù)據(jù)目錄放在了根目錄下,現(xiàn)在存儲空間不足,遇到這個問題如何解決呢,下面小編給大家?guī)砹薽ysql移動數(shù)據(jù)目錄啟動失敗解決方法,感興趣的朋友一起看看吧
    2023-04-04
  • mysql中的mvcc?原理詳解

    mysql中的mvcc?原理詳解

    MVCC多版本并發(fā)控制,是用來在數(shù)據(jù)庫中控制并發(fā)的方法,實現(xiàn)對數(shù)據(jù)庫的并發(fā)訪問用的,這篇文章主要介紹了mysql?mvcc?原理詳解,需要的朋友可以參考下
    2022-10-10

最新評論