表数据的批量插入
当一个表要插入数据库时,手动编写sql插入语句是不太现实的,效率也比较低。
我用的是SqlBulkCopy

public void ExecuteTransactionScopeInsertEx(DataTable dt, string tableName) { using (SqlBulkCopy sbc = new SqlBulkCopy(Common.ConnStr, SqlBulkCopyOptions.UseInternalTransaction)) { //服务器上目标表的名称 sbc.DestinationTableName = tableName; sbc.BatchSize = dt.Rows.Count; sbc.BulkCopyTimeout = 600; for (int i = 0, l = dt.Columns.Count; i < l; i++) { //列映射定义数据源中的列和目标表中的列之间的关系 sbc.ColumnMappings.Add(dt.Columns[i].ColumnName, dt.Columns[i].ColumnName); } sbc.WriteToServer(dt); } }
如果表的列名与数据库的列名不能一一对应,则需重载上述方法

public void ExecuteTransactionScopeInsertEx(DataTable dt, string tableName, string[] dbComlunName) { using (SqlBulkCopy sbc = new SqlBulkCopy(Common.ConnStr, SqlBulkCopyOptions.UseInternalTransaction)) { //服务器上目标表的名称 sbc.DestinationTableName = tableName; sbc.BatchSize = dt.Rows.Count; sbc.BulkCopyTimeout = 600; for (int i = 0, l = dt.Columns.Count; i < l; i++) { //列映射定义数据源中的列和目标表中的列之间的关系 sbc.ColumnMappings.Add(dt.Columns[i].ColumnName, dbComlunName[i]); } sbc.WriteToServer(dt); } }
如果需要自己指定控件的哪些列对应数据库的哪些列,则又需要重载

public void ExecuteTransactionScopeInsertEx(DataTable dt, string tableName, string[] displayName, string[] dbComlunName) { using (SqlBulkCopy sbc = new SqlBulkCopy(Common.ConnStr, SqlBulkCopyOptions.UseInternalTransaction)) { //服务器上目标表的名称 sbc.DestinationTableName = tableName; sbc.BatchSize = dt.Rows.Count; sbc.BulkCopyTimeout = 600; for (int i = 0, l = dt.Columns.Count; i < l; i++) { //列映射定义数据源中的列和目标表中的列之间的关系 sbc.ColumnMappings.Add(displayName[i], dbComlunName[i]); } sbc.WriteToServer(dt); } }
这样子基本可以解决表的批量插入了。不过如果是修改而不是插入呢。我的做法是先将该表原来需要修改的数据全删除,再执行本方法。
至于有更好的方法,我暂时还没有想到。。。还有这三个重载的方法如果归并为一个方法我也暂时没有想到很好的方法。。。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端