91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在MySQL中存儲文本和圖片

發布時間:2021-05-19 18:02:09 來源:億速云 閱讀:574 作者:Leah 欄目:MySQL數據庫

本篇文章為大家展示了怎么在MySQL中存儲文本和圖片,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

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中存儲文本和圖片,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和平区| 遵化市| 桃园县| 乐至县| 新乡县| 宁明县| 梅河口市| 德阳市| 漠河县| 米易县| 葵青区| 嵊泗县| 黎川县| 肥乡县| 华容县| 九寨沟县| 南开区| 吴忠市| 永宁县| 江华| 温泉县| 曲靖市| 都匀市| 阆中市| 金沙县| 望城县| 安达市| 亚东县| 淄博市| 固原市| 金堂县| 高阳县| 汉川市| 保亭| 拜泉县| 稻城县| 武川县| 安宁市| 塔城市| 天祝| 罗平县|