最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL存储文本和图片的方法

来源:动视网 责编:小采 时间:2020-11-09 21:16:44
文档

MySQL存储文本和图片的方法

MySQL存储文本和图片的方法:Oracle中大文本数据类型 Clob 长文本类型 (MySQL中不支持,使用的是text) Blob 二进制类型 MySQL数据库 Text 长文本类型 TINYTEXT: 256 bytes TEXT: 65,535 bytes => ~kb MEDIUMTEXT: 16,777,215 byte
推荐度:
导读MySQL存储文本和图片的方法:Oracle中大文本数据类型 Clob 长文本类型 (MySQL中不支持,使用的是text) Blob 二进制类型 MySQL数据库 Text 长文本类型 TINYTEXT: 256 bytes TEXT: 65,535 bytes => ~kb MEDIUMTEXT: 16,777,215 byte


Oracle中大文本数据类型

Clob 长文本类型 (MySQL中不支持,使用的是text)
Blob 二进制类型

MySQL数据库

Text 长文本类型
 TINYTEXT: 256 bytes
 TEXT: 65,535 bytes => ~kb
 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存储文本和图片的方法

MySQL存储文本和图片的方法:Oracle中大文本数据类型 Clob 长文本类型 (MySQL中不支持,使用的是text) Blob 二进制类型 MySQL数据库 Text 长文本类型 TINYTEXT: 256 bytes TEXT: 65,535 bytes => ~kb MEDIUMTEXT: 16,777,215 byte
推荐度:
标签: 图片 方法 文本
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top