背景:
前两天由于工作需要做个业务单据接口(支持批量处理),一般有接口发布为批量,但访问数据库时还是一张张单据处理,本次访问数据库也是批量操作。
 

内容:

研究发现Oracle批量操作有两种:1)BulkCopy 2)OracleCommand 。由于BulkCopy 的操作方式(表名、列映射、数据源)仅支持添加,无法做更新操作,所以不考虑此方式。

OracleCommand 在支持批量时,属性ArrayBindCount的值是至关重要的,它代表着一批的量,即如果你提供的参数的数组长度大于它的值,将以ArrayBindCount的值为长度标尺,大于这个的数据将被丢弃。本次准备:1)创建一张 student表 (ID int,Name varchar2(32)),引用Oracle.DataAccess

OracleConnection cn = new OracleConnection();
cn.ConnectionString = ConfigurationManager.ConnectionStrings["Oracle"].ConnectionString;
OracleCommand cmd = new OracleCommand();
cmd.CommandText = "Insert into student(id,name) values(:id,:name)";
cmd.Connection = cn; List<int> lsID=new List<int>();
List<string> lsName=new List<string>();
for (int i = ; i < ; i++)
{
lsID.Add(i);
lsName.Add("N"+i.ToString());
}
cmd.ArrayBindCount = ;//如果小于10 如8 则新增的行数 为8 而不是10 OracleParameter oracleParameterID = new OracleParameter();
oracleParameterID.ParameterName = "ID";
oracleParameterID.OracleDbType = OracleDbType.Int16;
oracleParameterID.Direction = ParameterDirection.Input;
oracleParameterID.Value = lsID.ToArray(); OracleParameter oracleParameterName = new OracleParameter();
oracleParameterName.ParameterName = "Name";
oracleParameterName.OracleDbType = OracleDbType.Varchar2;
oracleParameterName.Direction = ParameterDirection.Input;
oracleParameterName.Value = lsName.ToArray();
cmd.Parameters.Add(oracleParameterID);
cmd.Parameters.Add(oracleParameterName); cn.Open();
var t=cmd.ExecuteNonQuery();
cn.Close();

实验证明 批量新增、修改、删除 均 ok。但是在获取数据时,悲剧的发现不ok。

有点小小的遗憾,查了半天也没有发现原因,经讨论有三种办法:

1)拼接字符串,把条件拼接出来(例子中用in 就可以,但是实际中需要如((A=a and B=b)or(A=a1 and B=b1) …) ) 不易过长,大家知道这需要编译时间的;

2)创建临时表,把条件都插入到临时表中,然后关联临时表查询(比较麻烦,但速度还不错);

3)Command执行多次,把返回结果拼接起来 如(使用OracleDataAdapter.fill (datatable) 多次填充的时候,datatable 即为最终的查询结果集) 。

本次就记录到这吧,如果后续有更多思路再更新。

Oracle 批量操作的更多相关文章

  1. Oracle批量操作数据库

    1:批量插入 <insert id="insertBatch" parameterType="Java.util.List" > insert in ...

  2. oracle批量操作

    https://stackoverflow.com/questions/39576/best-way-to-do-multi-row-insert-in-oracle 1 批量insert 方式一: ...

  3. Oracle总结第二篇【视图、索引、事务、用户权限、批量操作】

    前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了-那么本篇主要总结关于Oralce视图.序列.事务的一些内容- 在数据库中,我们可以把各种的SQL语句分为四大类- (1 ...

  4. Oracle总结【视图、索引、事务、用户权限、批量操作】

    前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了...那么本篇主要总结关于Oralce视图.序列.事务的一些内容... 在数据库中,我们可以把各种的SQL语句分为四大类 ...

  5. mybatis oracle:批量操作(增删改查)

    此文主要是讲mybatis在连接oracle数据库时的一些批量操作,请各位对号入座 (最后回来补充一下,所有都是在Spring+MVC的框架下实现的) 不废话,上代码: 1.批量插入(网上很多,是针对 ...

  6. oracle学习笔记(二十三)——JDBC调用存储过程以及批量操作

    jdbc调用存储过程 使用并获得out模式的参数返回值 //存储过程为sum_sal(deptno department.deptno%type,sum in out number) Callable ...

  7. .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法

    1.添加引用 using Oracle.DataAccess.Client; using System.Configuration; 2.代码 增加方法 //DestinationTableName ...

  8. Oracle 和 mysql 的批量操作Sql语句 的区别

    正确的oracle批量新增的sql是: 方法 1: <insert id="insertAttractionsBatch" parameterType="java. ...

  9. .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法

    1./// <summary> /// 获取当前目标表结构 /// </summary> /// <param name="tableName"> ...

随机推荐

  1. nginx 配置文件解析(一)

    nginx.conf user nginx; # nginx服务的运行用户 worker_processes ; # 启动进程数,通常设置成和CPU的数量相等 error_log /var/log/n ...

  2. 使用HTML5中的Canves标签制作时钟特效

    <!DOCTYPE html > <html> <head> </head> <body> <canvas id="cloc ...

  3. IE6~9的css hack写法

    _color: red; /* ie6 */ *color: red; /* ie6/7 */ +color: red; /* ie6/7 */ color: red\0; /* ie8/9 */ c ...

  4. JDBC 基础概念

    1.概念:java与数据库连接 2.JDBC:是一个规范,提供接口(面向接口编程) 3.JDBC API:提供程序员调用的接口和类,集成在java.sql和javax.sql包中.如:DriverMa ...

  5. iOS知识点全梳理-备用

    感谢大神分享 文/Jack_lin(简书作者)原文链接:http://www.jianshu.com/p/5d2163640e26著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 序言 ...

  6. “express不是内部或外部命令”解决办法

    由于安装的Express是最新版本4.13.1,4.x版本就需要安装express-generator.命令如下:npm install -g express-generator ps: 1.卸载: ...

  7. Linux Makefile自动生成--config.h

    Linux Makefile自动生成--config.h http://blog.csdn.net/spch2008/article/details/12510805

  8. 工控主板对ISO7816智能卡标准的支持

    ISO7816是一套协议标准,这套协议不仅规定了智能IC卡的机械电气特性,而且还规定了智能IC卡的应用方法.智能IC卡的主要用途可归为身份识别.支付安全.加密/解密和信息存储四个方面.智能IC卡已经广 ...

  9. Keil伪指令

    Keil伪指令 目录 Keil伪指令... 1.     ALTNAME. 2 2.     BIT. 2 3.     BSEG.. 2 4.     CODE. 2 5.     CSEG.. 2 ...

  10. QT中共享库的生成与使用

    一. 静态库的生成1. 测试目录: lib2. 源码文件名: mywindow.h, mywindow.cpp, 类MyWindow继承于QPushButton, 并将文字设置为"I'm i ...