ADO.net实现批量SQL操作.

1. 反射数据适配器对象.

Type m_AdapterType = typeof(SqlDataAdapter);

IDbDataAdapter m_Adapter = (IDbDataAdapter)Activator.CreateInstance(m_AdapterType);

MethodInfo m_AddToBatch = m_AdapterType.GetMethod("AddToBatch", BindingFlags.NonPublic | BindingFlags.Instance);

MethodInfo m_ClearBatch = m_AdapterType.GetMethod("ClearBatch", BindingFlags.NonPublic | BindingFlags.Instance);

MethodInfo m_InitializeBatching = m_AdapterType.GetMethod("InitializeBatching", BindingFlags.NonPublic | BindingFlags.Instance);

MethodInfo m_ExecuteBatch = m_AdapterType.GetMethod("ExecuteBatch", BindingFlags.NonPublic | BindingFlags.Instance);

 

2.初始化适配器

IDbCommand cmd = Connection.CreateCommand();

 //事务

cmd.Transaction = Transaction;

switch (bcmd)//命令的类型, 枚举

{

case BatchCommandType.Insert:

m_Adapter.InsertCommand = cmd;

 break;

case BatchCommandType.Update:

 m_Adapter.UpdateCommand = cmd;

break;

case BatchCommandType.Delete:

m_Adapter.DeleteCommand = cmd;

break;

}

m_InitializeBatching.Invoke(m_Adapter, null);

 

3.将命令遍历, 添加到适配器中.

foreach (object parameter in parameterObjects)

{

//创建命令

IDbCommand mycmd = ........................

//添加到批命令

m_AddToBatch.Invoke(m_Adapter, new object[1] { mycmd });

}

 

4. 执行命令

OpenConnection();

//执行批处理

rows = (int)m_ExecuteBatch.Invoke(m_Adapter, null);

 

 5.关闭

m_ClearBatch.Invoke(m_Adapter, null);

 IDisposable dis = m_Adapter as IDisposable;

if (dis != null)

dis.Dispose();

m_Adapter = null;

 

ok;

转载于:https://www.cnblogs.com/leoxiong/archive/2010/09/19/1831266.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值