前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >blob类型字段[通俗易懂]

blob类型字段[通俗易懂]

作者头像
全栈程序员站长
发布2022-11-16 17:45:56
2.8K0
发布2022-11-16 17:45:56
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

1、在mysql中,bolb是一个二进制大型对象,是一个储存大量数据的容器,例如图片,音频。 2、插入blob类型数据比如使用preparedStatement,而不能使用Statment,因为blob类型数据不能使用字符串拼接。有关preparedStatement的使用请参考https://blog.csdn.net/weixin_46457946/article/details/119781227 3、mysql的四种blob类型

类型

大小

TinyBlob

255byte

Blob

65k

MediumBlob

16M

Long

4G

4、储存的文件过大,会造成数据库的性能下降。

一、Blob数据类型应用,向数据库中插入图片

代码语言:javascript
复制
 @Test
public void testInsert() { 

Connection conn=null;
PreparedStatement ps=null;
try { 

//1、连接数据库
conn = JDBCUtils.getConnection();
//2、预编译sql
String sql = "insert into customers(name,email,birth,photo) values(?,?,?,?)";
//3、获得PreparedStatement对象
ps = conn.prepareStatement(sql);
ps.setObject(1, "刘备");
ps.setObject(2, "liu@qq.com");
ps.setObject(3, "1992-09-08");
FileInputStream is = new FileInputStream(new File("推广004.png"));
ps.setBlob(4, is);
//提交
ps.execute();
} catch (Exception e) { 

e.printStackTrace();
} finally { 

JDBCUtils.closeResouce(conn, ps);
}
}

二、从数据库中读取Blob数据

代码语言:javascript
复制
@Test
public void testQuery(){ 

Connection conn=null;
PreparedStatement ps=null;
ResultSet rs=null;
InputStream is=null;
FileOutputStream fos=null;
try { 

//1、连接数据库
conn = JDBCUtils.getConnection();
//2、预编译sql
String sql = "select id,name,email,birth,photo from customers where id = ?";
ps = conn.prepareStatement(sql);
ps.setInt(1, 27);
//3、提交数据
rs = ps.executeQuery();
if(rs.next()){ 

int id=rs.getInt("id");
String name=rs.getString("name");
String email=rs.getString("email");
Date birth = rs.getDate("birth");
Customer cus = new Customer(id,name,email,birth);
System.out.println(cus);
//将Blob类型以文件的方式保存在本地
Blob photo = rs.getBlob("photo");
is = photo.getBinaryStream();
fos = new FileOutputStream("01.jpg");
byte[] buffer = new byte[1024];
int len;
while ((len=is.read(buffer))!=-1){ 

fos.write(buffer,0,len);
}
}
} catch (Exception e) { 

e.printStackTrace();
}finally { 

try { 

if(is != null)
is.close();
} catch (IOException e) { 

e.printStackTrace();
}
try { 

if(fos != null)
fos.close();
} catch (IOException e) { 

e.printStackTrace();
}
JDBCUtils.closeResource(conn,ps,rs);
}
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/215916.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月27日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档