实现方式是利用数据库访问类调用存储过程,利用循环逐条插入。很明显,这种方式效率并不高
方案二、使用Bulk插入
bulk方法主要思想是通过在客户端把数据都缓存在Table中,然后利用SqlBulkCopy一次性把Table中的数据插入到数据库,效率非常高
方案三:
利用SQLServer2008的新特性--表值参数(Table-Valued Parameter)。表值参数是SQLServer2008才有的一个新特性,使用这个新特性,我们可以把一个表类型作为参数传递到函数或存储过程里。
方案四:
对于单列字段,可以把要插入的数据进行字符串拼接,最后再在存储过程中拆分成数组,然后逐条插入。查了一下存储过程中参数的字符串的最大长度,然后除以字段的长度,算出一个值,很明显是可以满足要求的,只是这种方式跟第一种方式比起来,似乎没什么提高,因为原理都是一样的。
方案五:
考虑异步创建、消息队列等等。这种方案无论从设计上还是开发上,难度都是有的。
批量导入,我的理解是我们平时都是一条记录一条记录地插入,而批量导入就是超过一条记录一次性插入。比如有一个表A,一个表B,你想把表A中性别为男的记录导入表B,当然表A选出后的表结构和表B的表结构相同。假设A(ID,name,sex,age)表B(ID,name,age)批量导入的procedure为:(Oracle)create or replace PROCEDURE a2b
IS
BEGIN
SELECT A.ID,A.name,A.age
BULK COLLECT INTO B
FROM A
WHERE A.sex='male'
order by A.age
END
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)