oracle数据库喜欢搞特殊,二进制字段数据不能直接插入,需先再该字段插入oracle函数返回的的初始数据,然后在查询更新该字段。下面以Blob字段类型为例:

1.插入初始数据

Class.forName("oracle.jdbc.driver.OracleDriver");

Connection cn= DriverManager.getConnection("jdbc:oracle:thin:@192.168.0.5:1521:orcl", "qywsbspt", "qywsbspt123999");

cn.setAutoCommit(false);

PreparedStatement pst = cn.prepareStatement("insert into t_uploadfile (file_id,file_content) values (?,EMPTY_BLOB())");

pst.setObject(1,8888);

pst.excuteUpdate();

2.查询更新该字段

pst =   cn.prepareStatement("select  file_content  from t_uploadfile for updatewhere file_id = ? ");

pst.setObject(1,8888);

ResultSet rs = pst.excuteQuery();

BLOB blob = null ; //不是java.sql.Blob,而是oralce.sql.BLOB

if(rs.next())

blob = (BLOB)rs.getBlob(1);  //获取该字段

OutputStream os =blob.getBinaryOutputStream(); //打开操作该字段的流

InputStream is = ...... //获取要插入的二进制文件的输入流

int buffer = -1;

while((buffer = is.read())!=-1){

os.write(buffer);

}

is.close();

os.close();

cn.commit();

rs.close();

pst.close();

cn.close();

原文:http://www.cnblogs.com/cyhj/p/3978845.html

Oracle数据二进制传输,Oracle数据库插入二进制字段数据相关推荐

  1. java向Oracle数据库中插入blob字段数据

    java不能直接想插入其他普通类型数据一样插入blob字段数据,因为blob相当于一个大文件块,里面有游标,需要初始化blob游标才能插入数据.所以我们要先插入一个空的blob数据,以初始化游标,然后 ...

  2. python连接oracle数据库 插入clob类型数据

    python连接oracle数据库 插入clob类型数据 连接数据库 import cx_Oracle as cx #导入模块 con = cx.connect('root', 'root123', ...

  3. mysql java datetime_Java向mysql数据库插入datetime类型数据实例(精)

    在Mysql数据库中日期跟时间有两种: 1.date类型,date类型也就是我们常见的储存yyyy-MM-dd类型的日期,它不能储存时间,也就是只能储存日期, 2.dateitme就是可以储存日期同时 ...

  4. mysql插10万条数据_MySQL数据库插入100w条数据要花多久?

    MySQL数据库插入100w条数据要花多久? 1.多线程插入(单表) 2.多线程插入(多表) 3.预处理SQL 4.多值插入SQL 5.事务(N条提交一次) # 多线程插入(单表) 问:为何对同一个表 ...

  5. C#数据库插入多条数据,抛出异常:另一个 SqlParameterCollection 中已包含 SqlParameter

    解决办法很简单:添加语句:cmd.Parameters.Clear(); 原理:在SqlCommand使用完后清理SqlParameter. 代码示例: //定义连接数据库的配置字符串,需要填入你的连 ...

  6. mysql命令行批量添加数据_mysql命令行批量插入100条数据命令

    先介绍一个关键字的使用: delimiter 定好结束符为"$$",(定义的时候需要加上一个空格) 然后最后又定义为";", MYSQL的默认结束符为" ...

  7. C#使用ODAC向Oracle数据库插入海量实时数据

    上海浦东机场新建跑道埋设应力应变传感器,监测跑道日常数据,使用Micron某型号数据采集仪器和其对应的Enlight SDK做二次开发.期间采集的数据需精确到毫秒,使用C#自带的OracleClien ...

  8. Oracle——获取当前系统时间以及插入日期型数据(to_date的用法)

    获取当前系统时间 日期时间数据类型存储日期和时间值,包括年.月.日,小时.分钟.秒 主要的日期时间类型有: 1.DATE - 存储日期和时间部分,精确到整个的秒 语法 Select sysdate f ...

  9. Oracle 恢复dmp文件到数据库表中 【数据系列 1】

    Mac 恢复dmp文件数据到数据库表 软件环境:Mac电脑上安装的docker中安装的并且运行的镜像,参考自该博客docker安装oracle 我所运行安装的oracle版本为: Oracle Dat ...

最新文章

  1. Stack Overflow被收购了,以后要付费“抄代码”?
  2. 线程中如何使用对象_多线程中如何使用gdb精确定位死锁问题
  3. FreeRTOS---堆内存管理(一)
  4. [前台]---js+jquery校验姓名,手机号,身份证号
  5. css3动画与@keyframes关键帧
  6. 多多客DOODOOKE 1.x升级2.x指南
  7. python数据处理可以做什么菜_厌倦了EXCEL想玩点新花样?教你利用Python做数据筛选(下)...
  8. C Primer Plus 第七章 第七题
  9. expect实现自动通过堡垒机登陆
  10. 2022全新版千月影视源码原生播放器 投屏 选集 下载应有尽有(全开源)
  11. 电信校园网宽带创翼破解,路由器PPPOE拦截法
  12. 如何写一份成功的商业计划书
  13. 使用beautifulsoup4,爬取一波贴吧的表情包
  14. 3.32 小猪短租的爬虫-
  15. P4747 [CERC2017]Intrinsic Interval
  16. IE无法打开internet站点已终止操作的解决办法
  17. 在字符串中 快速查找
  18. Js 的防抖与节流代码分析
  19. matlab怎么调用桌面文件,Matlab界面Desktop操作桌面简介
  20. SVN Tortoise小乌龟在repo-browser上右键删除了文件目录 回滚解决办法

热门文章

  1. 谈谈在大公司和小公司的区别
  2. Pandas 导入excel、csv、txt 文件数据
  3. python Matplotlib 可视化总结归纳(二) 绘制多个图像单独显示多个函数绘制于一张图
  4. SU+GIS,让SketchUp模型在地图上活起来
  5. 差分管电路图_差分电路
  6. 用proxyee-down快速下载百度网盘大文件
  7. 毕业一年的大专生程序员工作总结(java后台)
  8. 1905协议详解(四)数据帧分析总览
  9. C++ 算法篇 穷举(枚举)
  10. android模拟器能刷推广吗,模拟玩安卓模拟器已成重度手游主要推广渠道