如何通过JDBC写入BLOB文件_setBinaryStream上传图片与大文件至数据库

PreparedStatement.setBinaryStream写不进数据库的主因是流被提前关闭或未触发实际写入,MySQL需配置useServerPrepStmts=true并传精确长度,PostgreSQL要求事务内操作且字段为bytea,Oracle不支持带长度参数的重载。PreparedStatement.setBinaryStream 为什么写不进数据库?常见现象是执行完 executeupdate() 没报错,但查数据库发现 blob 字段为 null 或空字节。根本原因不是 api 用错了,而是流被提前关闭或未触发实际写入。必须确保传入的 InputStream 在 executeUpdate() 调用前仍处于可读状态(比如文件没被 close,网络流没超时)MySQL 驱动默认把大对象当"客户端临时数据"处理,如果连接配置没开 useServerPrepStmts=true,setBinaryStream 可能被降级成 setBytes,悄悄把整个流加载进内存再转 byte[] ------ 大文件直接 OOMPostgreSQL 的 setBinaryStream 要求字段类型明确是 bytea,且不能在事务外调用(否则抛 PGSQLException: Large Objects may not be used outside a transaction)MySQL 和 PostgreSQL 的 setBinaryStream 参数差异两个主流驱动对第二个参数(长度)的处理逻辑完全不同,填错就静默失败。MySQL(Connector/J 8.0+):第二个参数是「精确字节数」,必须传真实长度;传 -1 会回退到 setBytes,传 0 直接写空 blobPostgreSQL(pgjdbc 42.6+):第二个参数是「最大预期长度」,可以略大于实际值(如传 10 * 1024 * 1024 写 5MB 图片),但不能为 0 或负数;传 -1 会抛异常Oracle(ojdbc8):不支持 setBinaryStream(int, InputStream, long) 重载,只能用 setBinaryStream(int, InputStream)(无长度参数),靠流 EOF 判断结束示例(MySQL 安全写法):File file = new File("/tmp/photo.jpg");try (FileInputStream fis = new FileInputStream(file)) { ps.setBinaryStream(1, fis, file.length()); // 必须是 file.length() ps.executeUpdate();}上传大文件时连接和事务怎么配才不崩BLOB 写入本质是长耗时 I/O,不调优的话,要么连不上,要么事务超时,要么驱动自己 abort。MySQL 连接串加 maxAllowedPacket=256M&connectTimeout=30000&socketTimeout=600000,否则 16MB 以上文件直接被服务端拒收PostgreSQL 必须显式开启事务:conn.setAutoCommit(false);ps = conn.prepareStatement("INSERT INTO docs(name, content) VALUES (?, ?)");ps.setBinaryStream(2, fis, fileSize);ps.executeUpdate();conn.commit(); // 不 commit,LOB 资源不释放别在 Spring @Transactional 方法里直接传 request.getInputStream() ------ HTTP 请求流只读一次,第二次调用 setBinaryStream 会读到空流为什么图片存进去了却打不开?不是编码问题,是内容被意外截断或污染。最常踩的三个坑: JoinMC智能客服 JoinMC智能客服,帮您熬夜加班,7X24小时全天候智能回复用户消息,自动维护媒体主页,全平台渠道集成管理,电商物流平台一键绑定,让您出海轻松无忧!

相关推荐
2301_816660212 小时前
如何重命名数据表_Operations面板表名修改方法
jvm·数据库·python
weixin_586061462 小时前
Navicat导入Excel表格报错怎么跳过_忽略错误记录高级选项
jvm·数据库·python
2301_773553622 小时前
golang如何理解编译指示pragma_golang编译指示pragma策略
jvm·数据库·python
qq_342295822 小时前
c++字符串运算_连接、比较、输入输出等运算符重载应用
jvm·数据库·python
【建模先锋】2 小时前
精品数据分享 | 锂电池数据集(10)基于阻抗的锂离子电池在不均衡使用情况下的性能预测
人工智能·python·深度学习·锂电池·锂电池寿命预测·锂电池数据集·剩余寿命预测
m0_746752302 小时前
如何生成ADDM报告_@addmrpt.sql自动数据库诊断监控工具
jvm·数据库·python
2301_814809862 小时前
如何快速查询SQL中的重复记录:GROUP BY与COUNT统计
jvm·数据库·python
m0_684501982 小时前
如何配置DG的备库延迟应用_DELAY参数实现在备库防范主库人为误操作逻辑错误
jvm·数据库·python
m0_515098422 小时前
Redis怎样强行终止陷入死循环的Lua脚本
jvm·数据库·python