问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

SQLSERVER数据库中批量导入数据的几种方法

发布网友 发布时间:2022-04-21 02:21

我来回答

2个回答

懂视网 时间:2022-04-08 00:59

 第一种方法:
Insert
部分数据还ok 批量数据性能问题。
第二种方法:
sqlbulkcopy 方法 主要思想 是在客户端将数据缓存到datatable里面,然后用sqlbulkcopy 一次性将数据插入到数据库表中
方法如下:

            System.Data.SqlClient.SqlBulkCopy bcp = new System.Data.SqlClient.SqlBulkCopy(connectionString);             //指定目标数据库的表名             bcp.DestinationTableName = "resulttable";             //建立数据源表字段和目标表中的列之间的映射             bcp.ColumnMappings.Add("sheetname", "sheetname");             bcp.ColumnMappings.Add("meters", "公里标");             bcp.ColumnMappings.Add("twista", "twista");             //写入数据库表 dt 是数据源DataTable             bcp.WriteToServer(dt);             //关闭SqlBulkCopy实例

            bcp.Close(); 
如果主键冲突会回滚插入操作,所以要么保证无冲突要么建临时表! 
第三种方法:
表值参数 tvps 需要先在sql上建立表值参数

--Create DataBase create database BulkTestDB; go use BulkTestDB; go --Create Table Create table BulkTestTable( Id int primary key, UserName nvarchar(32), Pwd varchar(16)) go --Create Table Valued CREATE TYPE BulkUdt AS TABLE   (Id int,    UserName nvarchar(32),

   Pwd varchar(16)) 

public static void TableValuedToDB(DataTable dt) {     SqlConnection sqlConn = new SqlConnection(       ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString);     const string TSqlStatement =      "insert into BulkTestTable (Id,UserName,Pwd)" +      " SELECT nc.Id, nc.UserName,nc.Pwd" +      " FROM @NewBulkTestTvp AS nc";     SqlCommand cmd = new SqlCommand(TSqlStatement, sqlConn);     SqlParameter catParam = cmd.Parameters.AddWithValue("@NewBulkTestTvp", dt);     catParam.SqlDbType = SqlDbType.Structured;     //表值参数的名字叫BulkUdt,在上面的建立测试环境的SQL中有。     catParam.TypeName = "dbo.BulkUdt";     try     {       sqlConn.Open();       if (dt != null && dt.Rows.Count != 0)       {           cmd.ExecuteNonQuery();       }     }     catch (Exception ex)     {       throw ex;     }     finally     {       sqlConn.Close();     } }


datatable序列化成json
调用jsonnet库
jsondata = JsonConvert.SerializeObject(dt, new DataTableConverter());

批量插入数据到sqlserver

标签:

热心网友 时间:2022-04-07 22:07

我们通过SQL脚本来插入数据,常见如下四种方式。

方式一:一条一条插入,性能最差,不建议使用。

INSERT INTO Proct(Id,Name,Price) VALUES(newid(),'牛栏1段',160);INSERT INTO Proct(Id,Name,Price) VALUES(newid(),'牛栏2段',260);
......

方式二:insert bulk

语法如下:

BULK INSERT [ [ 'database_name'.][ 'owner' ].]{ 'table_name' FROM 'data_file' }
WITH  (
[ BATCHSIZE [ = batch_size ] ],
[ CHECK_CONSTRAINTS ],
[ CODEPAGE [ = 'ACP' | 'OEM' | 'RAW' | 'code_page' ] ],
[ DATAFILETYPE [ = 'char' | 'native'| 'widechar' | 'widenative' ] ],
[ FIELDTERMINATOR [ = 'field_terminator' ] ],
[ FIRSTROW [ = first_row ] ],
[ FIRE_TRIGGERS ],
[ FORMATFILE = 'format_file_path' ],
[ KEEPIDENTITY ],
[ KEEPNULLS ],
[ KILOBYTES_PER_BATCH [ = kilobytes_per_batch ] ],
[ LASTROW [ = last_row ] ],
[ MAXERRORS [ = max_errors ] ],
[ ORDER ( { column [ ASC | DESC ] } [ ,...n ] ) ],
[ ROWS_PER_BATCH [ = rows_per_batch ] ],
[ ROWTERMINATOR [ = 'row_terminator' ] ],
[ TABLOCK ],
)  

相关参数说明:

BULK INSERT
[ database_name . [ schema_name ] . | schema_name . ] [ table_name | view_name ]
FROM 'data_file'
[ WITH
(
[ [ , ] BATCHSIZE = batch_size ]    --BATCHSIZE指令来设置在单个事务中可以插入到表中的记录的数量
[ [ , ] CHECK_CONSTRAINTS ]     --指定在大容量导入操作期间,必须检查所有对目标表或视图的约束。若没有 CHECK_CONSTRAINTS 选项,则所有 CHECK 和 FOREIGN KEY 约束都将被忽略,并且在此操作之后表的约束将标记为不可信。
[ [ , ] CODEPAGE = { 'ACP' | 'OEM' | 'RAW' | 'code_page' } ]  --指定该数据文件中数据的代码页
[ [ , ] DATAFILETYPE =
{ 'char' | 'native'| 'widechar' | 'widenative' } ]  --指定 BULK INSERT 使用指定的数据文件类型值执行导入操作。
[ [ , ] FIELDTERMINATOR = 'field_terminator' ]  --标识分隔内容的符号
[ [ , ] FIRSTROW = first_row ]    --指定要加载的第一行的行号。默认值是指定数据文件中的第一行
[ [ , ] FIRE_TRIGGERS ]     --是否启动触发器
[ [ , ] FORMATFILE = 'format_file_path' ]
[ [ , ] KEEPIDENTITY ]   --指定导入数据文件中的标识值用于标识列
[ [ , ] KEEPNULLS ]    --指定在大容量导入操作期间空列应保留一个空值,而不插入用于列的任何默认值
[ [ , ] KILOBYTES_PER_BATCH = kilobytes_per_batch ]
[ [ , ] LASTROW = last_row ]   --指定要加载的最后一行的行号
[ [ , ] MAXERRORS = max_errors ]   --指定允许在数据中出现的最多语法错误数,超过该数量后将取消大容量导入操作。
[ [ , ] ORDER ( { column [ ASC | DESC ] } [ ,...n ] ) ]  --指定数据文件中的数据如何排序
[ [ , ] ROWS_PER_BATCH = rows_per_batch ]
[ [ , ] ROWTERMINATOR = 'row_terminator' ]   --标识分隔行的符号
[ [ , ] TABLOCK ]     --指定为大容量导入操作持续时间获取一个表级锁
[ [ , ] ERRORFILE = 'file_name' ]   --指定用于收集格式有误且不能转换为 OLE DB 行集的行的文件。
)]  

方式三:INSERT INTO xx select...

INSERT INTO Proct(Id,Name,Price) SELECT NEWID(),'牛栏1段',160
UNION ALL
SELECT NEWID(),'牛栏2段',180 UNION ALL......

方式四:拼接SQL

INSERT INTO Proct(Id,Name,Price) VALUES(newid(),'牛栏1段',160)
,(newid(),'牛栏2段',260)
......

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
amd锐龙r75700g超频性价比装机方案,要核显性能综合表现超 架空电线故障如何排除 ...unexpected T_CONSTANT_ENCAPSED_STRING in 怎么解决这个错啊_百度... php错误Parse error: syntax error, unexpected T_CONSTANT_ENCAPSED_S... PHP出现如下情况 syntax error, unexpected T_ENCAPSED_AND_WHITES... php 如何捕获类似于Parse error: syntax error, unexpected T_CONSTA... 挂烫机如何熨西装 戗驳领西装怎么熨烫 西装前片怎么推拉拔烫 西装能不能拿去烫 怎样用sql语句在sqlserver建表 和插入数据~ sqlserver 怎么往表里插入数据 sqlserver怎么插入数据 怎样往 sqlserver数据库添加一个数据? 我的豌豆荚号被盗了可以用身份证找回吗 为什么苹果上的掌上lol的设置里无法绑定大区 英雄联盟奥菲娜的新手训练营绑定不了大区怎么办 打开英雄联盟活动网页,绑定不了大区怎么回事? lol掌盟怎么改绑定大区T谏 为什么英雄联盟的声望无法绑定大区啊说要10点才可以? 掌上英雄联盟怎么换绑定大区 在掌上英雄联盟怎么绑定大区啊 掌上英雄联盟怎么设置绑定德玛西亚区 LOL八周年战斗之夜宝箱升级任务有哪些 《掌上英雄联盟》如何更改绑定大区? 掌上英雄联盟为什么却换不了大区 只显示了一区 换不了其他大区 为什么LOL绑定大区的时候大区显示不出来一片空白? 怎么在掌上英雄联盟绑定别的大区 请问英雄联盟怎么绑定大区? lol违规id怎么绑定大区 sqlserver 创建临时表怎样插入数据 怎样用sql语句在sqlserver建表和插入数据 SqlServer往视图中插入数据的问题!! sqlserver 怎么快速插入一条数据 java中怎样向SQLserver中插入数据 c#怎样向sqlserver批量插入数据 sqlserver语句添加列(简单) 如何在SQLserver中利用循环语句插入大量的数据 SqlServer插入数据。将表A中的统计结果(3个)插入到表B中的某一行(3列)。 怎样快速向sqlserver插入上亿条数据 sqlserver 如何向数据库插入多条数据 数据条数不确定 sqlserver数据库执行更新时向另外数据表插入数据 怎样往 sqlserver数据库添加一个数据? sqlserver 下怎么建立数据库 怎么建表 美国北达科他大学和北达科他州立大学有什么区别 美国und在哪个洲 自费在美国学习飞行员,是UND还是purdue好? 匹兹堡州立大学 和北达科他大学哪个好? 美国中密歇根大学和美国北达科他大学哪个好 最好的外国大学是什么?