当前位置: 首页 > news >正文

如何通过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智能写作,写文档、写报告如此简单

http://www.jsqmd.com/news/668668/

相关文章:

  • AGI视觉理解进入临界点(2024Q3关键拐点报告):全球仅7个开源项目通过Spatial-Reasoning-Bench v2.1严苛测试
  • 【神经AI双轨验证】:为什么92%的AGI项目在2025Q4前必须重做底层认知架构?
  • VS Code写Rust卡顿?可能是Rust-Analyzer没配好!一份给新手的性能调优指南
  • 2025-2026年国内财税稽查应对公司推荐:五大知名服务评测对比企业跨境税务稽查应对痛点 - 品牌推荐
  • 贵阳找工作的人都在看地产销售,但他们忽略了一个赚钱更快的赛道 - 精选优质企业推荐官
  • 【Linux从入门到精通】第5篇:文件查看与搜索——别再只会用鼠标翻文件夹了
  • python trivy
  • 2025-2026年国际财税稽查应对公司推荐:五大口碑服务评测评价领先集团关联交易调整难题 - 品牌推荐
  • 2026年4月青海桥梁养护决策:伸缩缝密封胶厂家综合实力排行榜 - 2026年企业推荐榜
  • Scikit-learn:estimator 对象
  • 从Excel到出图:5分钟搞定Arcgis地统计向导绘制污染物浓度等值线图(附数据清洗技巧)
  • 使用Jmeter对接口进行压力测试
  • 创新项目实训汇报(四)
  • Rust的#[repr(transparent)]安全性
  • 2026年近期西藏道路养护优选:新乡金太阳新材料水性灌缝胶解决方案解析 - 2026年企业推荐榜
  • AGI与量子计算融合的7个致命断层:2026奇点大会未公开技术白皮书首曝
  • python grype
  • 基于 PaddleOCR v2.6.0 的图片文字识别实战(CPU 版)
  • 2025-2026年国内复旦大学考研培训机构评测:五家口碑服务推荐评价顶尖专业课薄弱 - 品牌推荐
  • 杰理之开启消人声之后提示音没声音【篇】
  • JavaScript中类属性与原型属性的覆盖规则详解
  • Python的__getattribute__与__getattr__的区别与陷阱
  • Java的模块路径与类路径在现代构建工具中的兼容性处理
  • 2026年4月复旦大学考研培训机构推荐:五家口碑服务评测对比领先跨考择校迷茫 - 品牌推荐
  • AGI推理延迟压至8.3ms?揭秘2026奇点大会上3家头部厂商联合发布的异构硬件栈,性能提升417%
  • 2026现阶段,在曹杨寻觅地道意式风味?这五家小众意大利披萨餐厅值得专程探访 - 2026年企业推荐榜
  • 别再死记硬背-32.44dB了!手把手带你从光速和单位换算,一步步推导出弗里斯公式常数
  • 基于深度确定性策略梯度的 PID 控制器实时自适应优化仿真研究(Matlab代码、Simulink仿真实现)
  • 终极Minecraft启动器指南:UltimMC让你的游戏体验更自由
  • Nessus扫描报告出来了,漏洞该谁修?一个真实案例讲透安全测试中的责任划分