如何在SQL Server中批量导入数据

如何在SQL Server中批量导入数据,第1张

方案一、循环导入

实现方式是利用数据库访问类调用存储过程,利用循环逐条插入。很明显,这种方式效率并不高

方案二、使用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


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11680303.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存