我有一个非常大的数据库,我需要发送给开发人员,这个表有超过1.2亿行。开发人员说,他只需要大约10,000行,所以我打算使用sqlcmd -s -d -Q "select top 10000 * from table“-S,”-o“C:\temp\filename.csv,而不是立即截断--我会写出表,重命名并测试大容量插入,然后尝试使用从'c:\temp\filename.csv‘开始的大容量插入表(字段终止符= ','\n’)
这以“第1行的大容量加载数据转换错误(截断)”结尾。错误。我还尝试了导入/导出向导,但由于同样的问题(截断),它失败了。增加字段长度,解决问题,但我真的有问题,理解为什么我需要这样做。它来自同一个表中的相同数据,它应该大容量插入回?!?而且,这个问题发生在表中的每一列上,并且以不同的长度发生,因此没有一个列具有我必须添加的相同数量的字符。所有列都是varchar数据类型。sqlcmd是否在文件中插入某种类型的损坏?我试图寻找一个问题,我也尝试了rtrim(列名),以确保没有空白,但我不确定这是如何运作。如果这有帮助的话,我将使用sql server 2012。谢谢
发布于 2015-08-20 21:21:50
您应该查看BCP、Queryout和BULK选项。如果要从SQL到SQL,请使用本机格式。
(BCP是命令行):
bcp "select top(10000) * from table" queryout "OUTPUTFILENAME.DAT" -S serverInstanceName -d databaseName -T -nBulk Insert命令是SQL (不是命令行):
bulk insert table from 'path\and\OUTPUTFILENAME.DAT' with (keepidentity,datafiletype = 'native');(如果表没有标识,则可以消除keepidentity,
https://stackoverflow.com/questions/32128255
复制相似问题