• 批量导入数据到mssql数据库的


    概述

    批量导入数据到数据库中,我们有好几种方式。

    1. 从一个数据表里生成数据脚本,到另一个数据库里执行脚本
    2. 从EXCEL里导入数据

    上面两种方式,导入的数据都会生成大量的日志。如果批量导入5W条数据到数据表里,就有生成5W条insert日志。那么这有好的方式处理这个问题吗?

    下面介绍另一种导入方式,批处理导入。

    批处理导入数据

    步骤一

    准备一个空的数据表Table,将你要导入的数据,全部导入到这个Table里,当然,这个数据表Table和你要导入的表结构是一模一样的。之后新建一个记事本,里面写上如下的批处理命令,保存命名为import.bat

    bcp [Test].dbo.Table OUT "d:/test.txt" -c -S 192.168.1.1 -U sa -P 123456
    
    pause

    上面的命令-U -S -T分别是什么意思,见后文。当前,如果你的数据库身份验证是windows,如果写成

    bcp [Test].dbo.Table OUT "d:/test.txt" -c -S 192.168.1.1 -T
    pause

    执行命令后,将得到一个记录得Table所有数据的test.txt文件。

    步骤二

    新建一个记事本,里面写批处理命令,将所有的数据都导入到指定的数据库表里

    bcp "[Test].dbo.Table" in "d:/test.txt" -c -S (local) -U sa -P 123456
    
    pause

    数据库身份验证是windows,写成

    bcp "[Test].dbo.Table" in "d:/test.txt" -c -S (local) -T
    
    pause

    bcp批处理命名解释

    [Test].dbo.Table:数据库表名

    d:/test.txt :要导入的数据

    -S  server_name[ instance_name] ,后面填的是服务器,上面是 (local),当然,填 . 也行

    -U login_id,后面指的是服务器登陆用户名

    -P password,后面指的是服务器登陆密码

    -T 指定 bcp 实用工具通过使用集成安全性的可信连接连接到 SQL Server。不需要网络用户的安全凭据、login_id  password。如果不指定 –T,则需要指定 –U  –P 才能成功登录

    解释完上面之后,接下来解释一下d:/test.txt

    这个文本里的数据是有格式的,数据表里有多少个字段,这里面就应该有多少字段,每个字段对应着数据表里的字段,中间用Tab键隔开。例如:

    51006    NULL    bbbbbbbbbbbbbbB    2015-12-31 00:00:00.000    0    NULL    1.00000    2    1    2015-02-09 12:08:28.017    jys    2015-02-09 12:08:28.017    jys    0
    51007    NULL    aaaaaaaaaaaaaaB    2015-12-31 00:00:00.000    0    NULL    1.00000    2    1    2015-02-09 12:08:28.017    jys    2015-02-09 12:08:28.017    jys    0
    51008    NULL    ccccccccccccccB    2015-12-31 00:00:00.000    0    NULL    1.00000    2    1    2015-02-09 12:08:28.017    jys    2015-02-09 12:08:28.017    jys    0

    如果第一列是自增ID,你填写的数值无效的,数据库会自动自增。

    结果

    最后,执行批处理文件命令即可,这样,导入数据生成的日志只有一条。

  • 相关阅读:
    【收集】各种hack
    CSS测试实录一:display的块状元素和行内元素的试验
    【转载加工】:after伪类+content内容生成经典应用举例
    CSS测试实录二:float和标准流
    onreadyStateChange  DOMContentLoaded
    Extensions
    Accessing of Rows in Silverlight DataGrid
    Linux应用程序的装载和执行
    top状态细分,进程状态
    定时器的使用和原理浅析,alarm/sleep函数
  • 原文地址:https://www.cnblogs.com/jys509/p/4364790.html
Copyright © 2020-2023  润新知