BulK INSERT
在sql Server中,BulK INSERT是用来将外部文件以一种特定的格式加载到数据库表的T-sql命令。该命令使开发人员能够直接将数据加载到数据库表中,而不需要使用类似于Integration Services这样的外部程序。虽然BulK INSERT不允许包含任何复杂的逻辑或转换,但能够提供与格式化相关的选项,并告诉我们导入是如何实现的。BulK INSERT有一个使用限制,就是只能将数据导入sql Server。
插入数据下面的例子能让我们更好的理解如何使用BulK INSERT命令。首先,我们来创建一个名为Sales的表,我们将要把来自文本文件的数据插入到这个表中。
CREATE table [dbo].[Sales] ( [SaleID] [int], [Product] [varchar](10) NulL, [SaleDate] [datetime] NulL, [SalePrice] [money] NulL ) |
当我们使用BulK INSERT命令来插入数据时,不要启动目标表中的触发器,因为触发器会减缓数据导入的进程。
在下一个例子中,我们将在Sales表上创建触发器,用来打印插入到表中的记录的数量。
CREATE TRIGGER tr_Sales ON Sales FOR INSERT AS BEGIN PRINT CAST(@@ROWCOUNT AS VARCHAR(5)) + ' rows Inserted.' END |
这里我们选择文本文件作为源数据文件,文本文件中的值通过逗号分割开。该文件包含1000条记录,而且其字段和Sales表的字段直接关联。由于该文本文件中的值是由逗号分割开的,我们只需要指定FIELDTERMINATOR即可。注意,当下面这条语句运行时,我们刚刚创建的触发器并没有启动:
BulK INSERT Sales FROM 'c:SalesText.txt' WITH (FIELDTERMINATOR = ',') |
当我们要的数据量非常大时,有时候就需要启动触发器。下面的脚本使用了FIRE_TRIGGERS选项来指明在目标表上的任何触发器都应当启动:
BulK INSERT Sales FROM 'c:SalesText.txt' WITH (FIELDTERMINATOR = ',', FIRE_TRIGGERS) |
我们可以使用BATCHSIZE指令来设置在单个事务中可以插入到表中的记录的数量。在前一个例子中,所有的1000条记录都在同一个事务中被插入到目标表里。下面的例子,我们将BATCHSIZE参数设置为2,也就是说要对该表执行500次独立的插入事务。这也意味着启动500次触发器,所以将有500咯打印指令输出到屏幕上。
BulK INSERT Sales FROM 'c:SalesText.txt' WITH (FIELDTERMINATOR = ', FIRE_TRIGGERS, BATCHSIZE = 2) |
BulK INSERT不仅仅可以应用于sql Server 2005的本地映射驱动器。下面的语句将告诉我们如何从名为fileServer的服务器的D盘中将SalesText文件的数据导入。
BulK INSERT Sales FROM 'fileServerD$SalesText.txt' WITH (FIELDTERMINATOR = ',') |
有时候,我们在执行导入 *** 作以前,最好能先查看一下将要输入的数据。下面的语句在使用BulK命令时,使用了OPENROWset函数,以便从SalesText文本文件中读取源数据。该语句同时还需要使用一个格式文件(此处没有列出文件的具体内容)来表明该文本文件中的数据格式。
SELECT * |
以上是内存溢出为你收集整理的SQL从文本导数据到数据库用到的BULK INSERT全部内容,希望文章能够帮你解决SQL从文本导数据到数据库用到的BULK INSERT所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)