如何通过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小时全天候智能回复用户消息,自动维护媒体主页,全平台渠道集成管理,电商物流平台一键绑定,让您出海轻松无忧!

相关推荐
倔强的石头_2 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB4 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码12 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
金銀銅鐵1 天前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸1 天前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络