如何通过C#读取Oracle数据库中的图片显示到WinForm_BLOB转Byte[]与流处理

Oracle BLOB字段读取必须用OracleCommand配合ExecuteScalar()或OracleDataAdapter获取OracleBlob对象,再调用GetStream()获取流并完整读入byte[],不可直接强转;须用Oracle.ManagedDataAccess,连接字符串加Pooling=false,流操作需在连接关闭前完成,UI更新须Invoke回主线程。Oracle BLOB 字段读取必须用 OracleCommand 配合 ExecuteScalar() 或 OracleDataAdapter,不能直接当字符串查oracle 的 blob 是二进制大对象,sql 查询里如果写 select photo from users 拿到的不是字节数组,而是一个 oracleblob 对象(或 dbnull),直接强转 byte[] 会崩------常见错误是 invalidcastexception 或空引用。正确做法是显式获取流或分块读取:用 ExecuteScalar() 获取 OracleBlob 实例,再调用其 GetStream() 方法若用 OracleDataAdapter.Fill() 填充 DataTable,字段值类型是 OracleBlob,仍需调用 GetStream(),不能直接 (byte[])row["photo"]别用 CommandBehavior.SequentialAccess 以外的方式读大 BLOB,否则可能内存爆掉WinForm 中显示图片前必须确保 byte[] 完整且格式可识别从 OracleBlob.GetStream() 读出来的流,得先全部读成 byte[] 才能喂给 PictureBox.Image。但注意:流位置可能不在开头,且 Oracle 驱动有时返回不可重置的流。实操建议:始终用 using (var stream = blob.GetStream()) { ... } 包裹,避免句柄泄漏用 stream.CopyTo(ms) 写入 MemoryStream,再调用 ms.ToArray() ------别用 stream.Read() 自己循环,容易漏字节检查 byte[] 开头是否为常见图片魔数(如 0xFF, 0xD8 表示 JPEG),防止数据库存了空/损坏数据导致 PictureBox 显示空白却不报错若图片尺寸大,考虑异步加载(Task.Run + Invoke 回 UI 线程),否则界面卡死OracleClient 已废弃,必须用 Oracle.ManagedDataAccess 并注意连接字符串里的 Pooling=false.NET Framework 自带的 System.Data.OracleClient 早在 2011 年就标记为废弃,VS 编译会警告,运行时在新系统上大概率失败。现在唯一靠谱的是 Oracle 官方的 Oracle.ManagedDataAccess NuGet 包。关键细节: 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单

相关推荐
辞旧 lekkk3 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
2301_809204704 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277774 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
Aaswk4 小时前
Java Lambda 表达式与流处理
java·开发语言·python
笨蛋不要掉眼泪5 小时前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite5 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋95 小时前
ruoyi项目更换为mysql9.7.0数据库
数据库
Andya_net6 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql
Cyber4K6 小时前
【Python专项】进阶语法-系统资源监控与数据采集(1)
开发语言·python·php
冷小鱼6 小时前
JVM 异常崩溃排查全指南:从 Core Dump 到根因定位
jvm