BCP的基础用法可以参考上一篇:http://www.cnblogs.com/Gin-23333/p/5489889.html

这篇是补充一些有可能会用到,但是出场几率并不算大的几个参数

1、首先是 -F -L ,形象生动的来说就是 FirstRow 和LastRow 的参数,比如以下例子(测试的表用回之前那个)

ID          name                                               Chinese     Math
----------- -------------------------------------------------- ----------- -----------
1 张三 90 80
2 李四 75 90
3 王五 68 100
4 赵六 100 NULL
5 うずまき ナルト 59 80

然后配合这个测试语句导出\导入数据

exec sys.xp_cmdshell 'bcp test.dbo.t3 out D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c'
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c -F 2 -L 4' select * from t4
ID name Chinese Math
----------- -------------------------------------------------- ----------- -----------
1 李四 75 90
2 王五 68 100
3 赵六 100 -1

对比原来t3的数据,先不要对正 ID列,看下数据行数,-F 和 -L 的参数意义是从第几行还是,截至到第几行,和平时类似使用的 offset next 和 limit 1,1 这些不一样。这个在导数据的时候需要注意一下。

2、关于标识列的去留。对于上面一个例子,虽然导出的数据是存在ID列的,但是导入的时候却跟原本的ID列的值不一致。在BCP里面也是可以处理,使用-E 参数来进行控制

exec sys.xp_cmdshell 'bcp test.dbo.t3 out D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c'
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c -E -F 2 -L 4' select * from t4 ID name Chinese Math
----------- -------------------------------------------------- ----------- -----------
2 李四 75 90
3 王五 68 100
4 赵六 100 -1

如上面例子所显示,原本t3的标识列已经带到t4里面。

3、处理默认值的用法,导出/导入数据的时候,导入到新表的时候,如果对应的值为null,那么如果导入的对应列存在默认值,则会插入默认值。如果要保持Null 值则可以用-k 的参数

修改一下表对象,往里面的Math 字段添加一个默认值
alter table t4 add constraint DF_t4_Math default -1 for Math
--保留数据Null值不填充默认值
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c '
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c '
ID name Chinese Math
----------- -------------------------------------------------- ----------- -----------
1 张三 90 80
2 李四 75 90
3 王五 68 100
4 赵六 100 -1
5 うずまき ナルト 59 80 exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c -k'
ID name Chinese Math
----------- -------------------------------------------------- ----------- -----------
1 张三 90 80
2 李四 75 90
3 王五 68 100
4 赵六 100 NULL
5 うずまき ナルト 59 80

虽然说可以指定是否保留导入数据的Null值,但是要说明一点,如果存在多列有默认值的列,目前的版本在导入的时候要么选择全部取默认值,要么全部保留Null值,不能A列使用默认值而B列保留空,这个需要留意一下

4、BatchSize 这个也挺好用。 -b 参数,相当于每次导出/导入多少条数据。这样的好处是当数据量很大的时候,假如途中出错,在出错的前面批次的数据都可以正常导入,将不会影响之前导入的数据。

--每个批次传入的数据行数
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c -b 1'
exec sys.xp_cmdshell 'bcp test.dbo.t4 in D:\t3 -S GINLATOP\MSSQLSERVER2016 -T -c -b 1' output
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
NULL
开始复制...
已向 SQL Server 发送了 1 行。总共发送了: 1
已向 SQL Server 发送了 1 行。总共发送了: 2
已向 SQL Server 发送了 1 行。总共发送了: 3
已向 SQL Server 发送了 1 行。总共发送了: 4
已向 SQL Server 发送了 1 行。总共发送了: 5
NULL
已复制 5 行。
网络数据包大小(字节): 4096
总时钟时间(毫秒) : 1 平均值: (每秒 5000.00 行。)
NULL

5条数据分开了5次进行发送,这个就是-b 的作用。

BCP笔记整理(二)的更多相关文章

  1. Deep Learning(深度学习)学习笔记整理(二)

    本文整理了网上几位大牛的博客,详细地讲解了CNN的基础结构与核心思想,欢迎交流. [1]Deep learning简介 [2]Deep Learning训练过程 [3]Deep Learning模型之 ...

  2. Struts2学习笔记整理(二)

    这里是重点. Action接口 struts2 的Action可以是POJO 为了让用户开发的Action更加规范struts2提供了一个Action接口 ActionSupport基类 Struts ...

  3. HTML+CSS学习笔记整理二

    盒子模型CSS(重点) 边框border     边框通常使用连写border:1px(边框大小) solid(实线或其他)  red(颜色) border-collapse:collapse (合并 ...

  4. Deep Learning(深度学习)学习笔记整理系列之(二)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  5. 一篇笔记整理JVM工作原理

    首先要了解的 >>数据类型 Java虚拟机中,数据类型可以分为两类:基本类型和引用类型. 基本类型的变量保存原始值,即:他代表的值就是数值本身:而引用类型的变量保存引用值.“引用值”代表了 ...

  6. Deep Learning(深度学习)学习笔记整理系列之(五)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  7. 关于ARP欺骗与MITM(中间人攻击)的一些笔记( 二 )

    一直没有折腾啥东西,直到最近kali Linux发布,才回想起应该更新博客了….. 再次说明,这些技术并不是本人原创的,而是以前记录在Evernote的旧内容(排版不是很好,请谅解),本文是继关于AR ...

  8. Deep Learning(深度学习)学习笔记整理系列之(八)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  9. Deep Learning(深度学习)学习笔记整理系列之(七)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

随机推荐

  1. JDBC连接SQL Server代码模板

    *                  JDBC连接SQL Server数据库 代码模板* Connection: 连接数据库并担任传送数据的任务:* Statement :  执行SQL语句:* Re ...

  2. 使用Microsoft Roslyn提取C#和VB.NET源代码中的字符串常量

    Microsoft Roslyn是微软.NET“编译器即服务(Compiler as a Service)”的主要产品,它提供了开放的编译器API,并为源代码产生.分析和重构提供了新一代的语言对象模型 ...

  3. Linux日志定时清理

    linux是一个很能自动产生文件的系统,日志.邮件.备份等.虽然现在硬盘廉价,我们可以有很多硬盘空间供这些文件浪费,让系统定时清理一些不需要的文件很有一种爽快的事情.不用你去每天惦记着是否需要清理日志 ...

  4. Net设计模式实例之原型模式( Prototype Pattern)

    一.原型模式简介(Brief Introduction) 原型模式(Prototype Pattern):用原型实例指定创建对象的种类,并通过拷贝这些原型创建新的对象. Specify the kin ...

  5. 创建ASP.NET Core MVC应用程序(6)-添加验证

    创建ASP.NET Core MVC应用程序(6)-添加验证 DRY原则 DRY("Don't Repeat Yourself")是MVC的设计原则之一.ASP.NET MVC鼓励 ...

  6. @Html.Raw显示一张图片

    在ASP.NET MVC中,显示一张图片,是很方便的事情,完全可以在控制器中组合html代码,并传给视图. 下面一个简单的例子: public ActionResult HtmlRawImage() ...

  7. html5数字和颜色输入框

    html5功能强大,数字和颜色输入框例子 效果:http://hovertree.com/code/html5/rxujb6g8.htm <!DOCTYPE html> <html& ...

  8. Hadoop单机伪分布式

    环境配置:Ubuntu11.10,Hadoop1.0.0 安装ssh 1 apt-get install ssh 安装rsy 1 apt-get install rsync 配置ssh免密码登录 1 ...

  9. Understanding glibc malloc【待译】

    今天尝试用Valgrind调试程序时,发现堆和栈的一些问题没有理解透彻,于是Google了下"Memory Layout C",接着就通过Memory Layout of C Pr ...

  10. 推荐15款最佳的 jQuery 分步引导插件

    当用户浏览到一个网站,它可能从不知道如何浏览,如何操作网站或 Web 应用程序的内容和流程.在这篇文章中,我们编制了一些最好的 jQuery 引导插件列表.你会发现这些插件对于提高你的网站的整体用户体 ...