传智播客--ADO.net--SqlBulkCopy批量插入数据(小白必知)
一般情况下,我们在向数据库中插入数据时用Insert语句,但是当数据量很大的时候,这种情况就比较缓慢了,这个时候就需要SqlBulkCopy这个类。
SqlBulkCopy本身常用的函数有这么几个
DestinationTableName-----服务器目标表上的名称,也就是你要向哪个表插入大量的数据,这个就设置为那个表名
ColumnMappings-----字段映射,因为是要在本地建立一个Table,然后将整个Table一次性的加入到数据库中,因此需要将本地的Table的字段和数据库表中的字段做好映射关系
WriteToServer-----这个就是写入数据库了,不需要多说
导入的数据是传智播客免费视频上提供的手机号码归属地的信息,插入数据库看了一下,一共有258113条数据,用时大概6秒吧。
private void btnDR_Click(object sender, RoutedEventArgs e) { OpenFileDialog ofd = new OpenFileDialog(); ofd.Filter = "文本文件|*.txt"; if(ofd.ShowDialog()!=true) { return; } DateTime time = DateTime.Now;//计时,看看花了多长时间 DataTable table = new DataTable();//本地创建一个临时表 //给临时表添加列名 table.Columns.Add("HD"); table.Columns.Add("DQ"); table.Columns.Add("LX"); using(StreamReader streamReader=new StreamReader(ofd.FileName,Encoding.Default))//读取文件 { while(!streamReader.EndOfStream) { string[] stringStream = streamReader.ReadLine().Split('\t');//按行读取,通过\t进行分割,得到数组 string HD = stringStream[0].Trim('"'); string DQ = stringStream[1].Trim('"'); string LX = stringStream[2].Trim('"'); //将数据插入到本地创建的临时表里 DataRow row = table.NewRow(); row["HD"] = HD; row["DQ"] = DQ; row["LX"] = LX; table.Rows.Add(row); } } //这部分就是从本地导入到数据库中 using(SqlConnection conn=new SqlConnection("Data Source=.;Initial Catalog=imageprocess;Integrated Security=True")) { conn.Open(); using(SqlBulkCopy bulkCopy=new SqlBulkCopy(conn)) { bulkCopy.DestinationTableName = "T_HM"; bulkCopy.ColumnMappings.Add("HD", "HD");//前面的参数是本地的临时Table列名,后面的参数是数据库的列名。两个名称不需要相同,我写相同,是为了方便 bulkCopy.ColumnMappings.Add("DQ", "DQ"); bulkCopy.ColumnMappings.Add("LX", "LX"); bulkCopy.WriteToServer(table); } } TimeSpan TS = DateTime.Now - time; MessageBox.Show(TS.ToString()); }
作者:眾尋
出处:https://www.cnblogs.com/ZXdeveloper/p/4125857.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本