Oracle 批量操作
背景:
前两天由于工作需要做个业务单据接口(支持批量处理),一般有接口发布为批量,但访问数据库时还是一张张单据处理,本次访问数据库也是批量操作。
内容:
研究发现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 批量操作的更多相关文章
- Oracle批量操作数据库
1:批量插入 <insert id="insertBatch" parameterType="Java.util.List" > insert in ...
- oracle批量操作
https://stackoverflow.com/questions/39576/best-way-to-do-multi-row-insert-in-oracle 1 批量insert 方式一: ...
- Oracle总结第二篇【视图、索引、事务、用户权限、批量操作】
前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了-那么本篇主要总结关于Oralce视图.序列.事务的一些内容- 在数据库中,我们可以把各种的SQL语句分为四大类- (1 ...
- Oracle总结【视图、索引、事务、用户权限、批量操作】
前言 在Oracle总结的第一篇中,我们已经总结了一些常用的SQL相关的知识点了...那么本篇主要总结关于Oralce视图.序列.事务的一些内容... 在数据库中,我们可以把各种的SQL语句分为四大类 ...
- mybatis oracle:批量操作(增删改查)
此文主要是讲mybatis在连接oracle数据库时的一些批量操作,请各位对号入座 (最后回来补充一下,所有都是在Spring+MVC的框架下实现的) 不废话,上代码: 1.批量插入(网上很多,是针对 ...
- oracle学习笔记(二十三)——JDBC调用存储过程以及批量操作
jdbc调用存储过程 使用并获得out模式的参数返回值 //存储过程为sum_sal(deptno department.deptno%type,sum in out number) Callable ...
- .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法
1.添加引用 using Oracle.DataAccess.Client; using System.Configuration; 2.代码 增加方法 //DestinationTableName ...
- Oracle 和 mysql 的批量操作Sql语句 的区别
正确的oracle批量新增的sql是: 方法 1: <insert id="insertAttractionsBatch" parameterType="java. ...
- .net 调用Oracle.Data.Access 组件提供的用于批量操作的方法—获取数据库表结构方法和跟参数赋值方法
1./// <summary> /// 获取当前目标表结构 /// </summary> /// <param name="tableName"> ...
随机推荐
- HTML常见标签学习与笔记总结
HTML其实就是把页面的数据封装并加上标签 表头<head> <title> 浏览器标题栏显示的内容 <base> 有href和target属性,href指定网页中 ...
- Unity5.3——UI之Canvas
原文:http://docs.unity3d.com/Manual/UISystem.html Canvas 所有的UI都应该放在Canvas里面(子层).Canvas是一个带有Canvas组件的Ga ...
- (搬运工)推荐!国外程序员整理的 C++ 资源大全
标准库 C++标准库,包括了STL容器,算法和函数等. C++ Standard Library:是一系列类和函数的集合,使用核心语言编写,也是C++ISO自身标准的一部分. Standard Tem ...
- SQLServer分页
1.为什么要分页? 当显示数据的时候,我们不会一下子把所有的数据都显示出来,比如说表中有一万条数据,难道我们要把一万条数据都一次性的显示出来吗?!即便显示给用户了,用户也看不过来.因此,不论是从效率的 ...
- String 和 string 的区别
string是c#中的类,String是.net Framework的类(在c# IDE中不会显示蓝色)c# string映射为.net Framework的String如果用string,编译器会把 ...
- NGINX小技巧--将所有目录和目录下所有文件分别给与不同的权限
为了安全,有时要将文件的权限进行限制,但,目录如果没有755,则不能进入. 所以需要分别给权限 find ./ -type f -name "*" |xargs ls -l
- 深入浅出Node.js (7) - 网络编程
7.1 构建TCP服务 7.1.1 TCP 7.1.2 创建TCP服务器端 7.1.3 TCP服务的事件 7.2 构建UDP服务 7.2.1 创建UDP套接字 7.2.2 创建UDP服务器端 7.2. ...
- 【转】深入理解Android的startservice和bindservice--不错
原文网址:http://www.cnblogs.com/yejiurui/p/3429451.html 一.首先,让我们确认下什么是service? service就是android系 ...
- hdu5017:补题系列之西安网络赛1011
补题系列之西安网络赛1011 题目大意:给定一个椭球: 求它到原点的最短距离. 思路: 对于一个椭球的标准方程 x^2/a^2 + y^2/b^2 +z^2/c^2=1 来说,它到原点的最短距离即为m ...
- javascript笔记2之数据类型
/* var box; alert(typeof box); //box是Undefined类型,值是undefined,类型返回的字符串是undefined var box = true; aler ...

