zoukankan      html  css  js  c++  java
  • Bulk Insert:将文本数据(csv和txt)导入到数据库中

    将文本数据导入到数据库中的方法有很多,将文本格式(csv和txt)导入到SQL Server中,bulk insert是最简单的实现方法

    1,bulk insert命令,经过简化如下

    BULK INSERT schema_name . table_name 
    FROM 'data_file' 
    WITH 
    (
    FIELDTERMINATOR = 'field_terminator',
    ROWTERMINATOR = 'row_terminator',
    DATAFILETYPE=‘WideChar’
    );

    2,使用bulk insert 将txt数据导入到数据库中,文本数据使用Tab分割Column,使用换行符分割row。

    --create staging table
    create table dbo.txt_staging
    (
    col1 nvarchar(255),
    col2 nvarchar(255),
    col3 nvarchar(255)
    )
    go
    
    --populate data 
    bulk insert dbo.txt_staging
    from N'D:	est.txt'
    WITH(
        FIELDTERMINATOR = '	',
        ROWTERMINATOR = '
    '
    )

    3,使用bulk insert 将csv的数据导入数据库中
    CSV文件使用“,”作为列分隔符,使用“ ”作为行分隔符

    --populate data 
    bulk insert dbo.txt_staging
    from N'D:abc.csv'
    WITH(
        FIELDTERMINATOR = N',',
        ROWTERMINATOR = N'
    ',
        CODEPAGE =N'raw'
    )

    3,在导入Unicode时,需要将.txt文档保存为Unicode 编码方式

    在使用bulk insert导入时,必须设置DATAFILETYPE='widechar',选项可能值有: 'char' | 'native'| 'widechar' | 'widenative' ,默认值是char。

    如果有些Column没有值,设置 KEEPNULLS   选项,表示将该column设置为NULL。

    bulk insert dbo.txt_staging
    from N'D:abc.txt'
    WITH(
        FIELDTERMINATOR = '	',
        ROWTERMINATOR = '
    ',
        DATAFILETYPE ='widechar' ,
        KEEPNULLS
    )

    附:Bulk Insert 命令的调用格式:

    • BULK INSERT  [ schema_name ] . [ table_name ]    
    • FROM 'data_file'    
    • WITH (Arguments)]

    重要参数注释:

    • data_file ':指定数据文件的full path,bulk insert命令将数据从该文件导入到Target Table中
    • ROWTERMINATOR 'row_terminator' : 指定分隔行的字符,使用该字符来分割行(Row);
    • FIELDTERMINATOR 'field_terminator' :指定分隔字段的字符,使用该字符来分割字段(Field或Column);
    • DATAFILETYPE = { 'char' | 'native'| 'widechar' | 'widenative' }:指定data file编码(Encoding)的类型,推荐使用widechar编码;
    • CODEPAGE = { 'ACP' | 'OEM' | 'RAW' | 'code_page' } :如果 data file 中含有单字节(char或varchar)字符数据,使用CodePage参数指定字符列的CodePage;
    • BATCHSIZE = batch_size :指定一个batch包含的数据行数量,在将数据复制到Table中时,每一个Batch作为一个单独的事务,如果一个batch复制失败,那么事务回滚。默认情况下,data file中的所有数据作为一个batch。Specifies the number of rows in a batch. Each batch is copied to the server as one transaction. If this fails, SQL Server commits or rolls back the transaction for every batch. By default, all data in the specified data file is one batch. 
    • CHECK_CONSTRAINTS :指定在执行bulk insert操作期间,必须检查插入的数据是否满足Target Table上的所有约束。如果没有指定 CHECK_CONSTRAINTS 选项,则所有 CHECK 和 FOREIGN KEY 约束都将被忽略,并且,在此操作之后,表上的所有约束将标记为不可信(not-trusted);   
    • FIRE_TRIGGERS :指定是否启动Insert触发器,如果指定该选项,每个batch成功插入后,会执行Insert触发器;如果不指定该选项,不会执行Insert 触发器;
    • KEEPIDENTITY :指定将data file中的标识值插入到标识列(Identity Column)中,如果不指定KeepIdentity选项,Target Table中的ID列会自动分配唯一的标识值;  
    • KEEPNULLS:指定在执行bulk insert操作期间,空列(Empty Columns)应保留NULL值,而不是插入列的默认值
    • TABLOCK :指定在执行bulk insert操作期间,获取一个表级锁,持有表级锁,能够减少锁竞争(Lock Contention),提高导入性能

    参考doc:

    BULK INSERT (Transact-SQL)

  • 相关阅读:
    关于同时上传多个图片的类(有点粗糙)
    关于上传图片的类(有点粗糙)
    关于分页的类(有点粗糙)
    php是什么
    关于glod方法的使用和介绍
    PHP中从数据库获取查询结果时容易出的错误及原因(smarty)
    转载- 支持Android4.0以下webp的使用
    Android用户体验
    转载-Android数据库高手秘籍(一)——SQLite命令
    转载 -安卓开发-Activity中finish() onDestroy() 和System.exit()的区别
  • 原文地址:https://www.cnblogs.com/ljhdo/p/5604912.html
Copyright © 2011-2022 走看看