校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > MySQL存儲文本和圖片的方法

MySQL存儲文本和圖片的方法

熱門標簽:電銷機器人 行業 溫州瑞安400電話怎么申請 電話機器人市場趨勢 南昌高頻外呼系統哪家公司做的好 俄國地圖標注app 電銷機器人各個細節介紹 百度地圖標注后不顯示 昆明電信400電話辦理 淄博400電話申請

Oracle中大文本數據類型

Clob  長文本類型  (MySQL中不支持,使用的是text)
Blob  二進制類型

MySQL數據庫

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  -- 圖片字段
);

存儲文本時是以字符類型存儲,存儲圖片時是以二進制類型存儲,具體使用的設置參數方法,和獲取數據方法不同。

例如:

// 存儲文本時
// 存儲時,設置參數為字符流 FileReader reader
pstmt.setCharacterStream(1, reader);
// 獲取參數時
// 方式1:
Reader r = rs.getCharacterStream("content");
// 獲取長文本數據, 方式2:
System.out.print(rs.getString("content"));
// 存儲二進制圖片時 
// 設置參數為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);
    // 設置參數
    // 獲取文本
    File file = new File("f:/a.jpg");
    InputStream in = new FileInputStream(file);
    // 設置參數為2進制流
    pstmt.setBinaryStream(1, in);
    // 執行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);
    // 設置參數
    pstmt.setInt(1, 2);
    // 執行查詢
    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實現類似Oracle序列的方案
  • mysql實現sequence功能的代碼
  • Can''t connect to local MySQL through socket ''/tmp/mysql.sock''解決方法
  • Mysql常用函數大全(分類匯總講解)
  • 利用MySQL主從配置實現讀寫分離減輕數據庫壓力
  • mysql+spring+mybatis實現數據庫讀寫分離的代碼配置
  • 如何徹底刪除mysql服務(清理注冊表)詳解
  • 將圖片儲存在MySQL數據庫中的幾種方法
  • Ubuntu上mysql的安裝及使用(通用版)
  • insert和select結合實現"插入某字段在數據庫中的最大值+1"的方法

標簽:拉薩 海口 安徽 葫蘆島 嘉峪關 吐魯番 甘南 洛陽

巨人網絡通訊聲明:本文標題《MySQL存儲文本和圖片的方法》,本文關鍵詞  MySQL,存儲,文本,和,圖片,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL存儲文本和圖片的方法》相關的同類信息!
  • 本頁收集關于MySQL存儲文本和圖片的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 青阳县| 游戏| 轮台县| 钟祥市| 曲麻莱县| 安吉县| 浦东新区| 颍上县| 武乡县| 商河县| 淅川县| 南郑县| 睢宁县| 花莲县| 黄大仙区| 江西省| 阿拉善左旗| 观塘区| 东方市| 柘荣县| 射阳县| 商南县| 舒城县| 谢通门县| 三门峡市| 新野县| 米林县| 湘潭县| 长海县| 治县。| 永年县| 铜陵市| 永平县| 尚义县| 黄冈市| 罗源县| 齐齐哈尔市| 松原市| 探索| 凭祥市| 朝阳市|