当前位置: 首页 > 编程笔记 >

MySQL存储文本和图片的方法

公西天逸
2023-03-14
本文向大家介绍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();
    }
  }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。如果你想了解更多相关内容请查看下面相关链接

 类似资料:
  • 本文向大家介绍PHP操作MySQL中BLOB字段的方法示例【存储文本与图片】,包括了PHP操作MySQL中BLOB字段的方法示例【存储文本与图片】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP操作MySQL中BLOB字段的方法。分享给大家供大家参考,具体如下: 1、MySQL中BLOB字段类型 BLOB类型的字段用于存储二进制数据。 MySQL中,BLOB是个类型系列,包括:Tin

  • 我正在学习本教程,内容是拍摄图片,显示缩略图,并将完整的图片存储在本地公共存储空间中,仅供我的应用程序使用。 问题:尝试访问应用程序的本地存储时,EACCESS(权限被拒绝 谢谢你抽出时间!

  • 本文向大家介绍Java 读取PDF中的文本和图片的方法,包括了Java 读取PDF中的文本和图片的方法的使用技巧和注意事项,需要的朋友参考一下 本文将介绍通过Java程序来读取PDF文档中的文本和图片的方法。分别调用方法extractText()和extractImages()来读取。 使用工具:Free Spire.PDF for Java(免费版) Jar文件获取导入: 方法1:通过官网下载j

  • 本文向大家介绍iOS archive保存图片到本地的方法,包括了iOS archive保存图片到本地的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了iOS保存图片到本地的具体代码,供大家参考,具体内容如下 一、工程图 二、代码 RootViewController.h RootViewController.m 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持

  • 图是一个好东西,能够使用图来模拟或解决很多生活问题,同时在各大比赛上都少不了有关于图的问题.图是关系与顶点与边的,那么我们该如何来存入图的信息呢? (1)直接存边 我们开一个数组,数组里每个元素是图的一条边。其中存的每一条边都包含这些信息:顶点 v 与 u , 边的权值。 这就用到结构体数组,对于无向图,只需要存两个顶点 , 有向图的话需要区分起点、终点。 // 直接存边  struct edg

  • 本文向大家介绍python保存网页图片到本地的方法,包括了python保存网页图片到本地的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python保存网页图片到本地的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。