




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、亍式一:实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环来拼接sql,这样做不但容易出错而且效率低下,最好的办法是使用bcp,也就是System.Data.SqlClient.SqlBulkCopy类来实现。usingSystem;usingSystem.Data;usingSystem.Windows.Forms;usingSystem.Data.OleDb;namespaceWindowsApplication2publicpartialclassForm1:FormpublicForm1()InitializeComponent();privatevo
2、idbutton1_Click(objectsender,EventArgse)/测试,将excel中的sheet1导入到sqlserver中stringconnString"server=localhost;uid=sa;pwd=sqlgis;database=master"System.Windows.Forms.OpenFileDialogfd=newOpenFileDialog();if(fd.ShowDialog()=DialogResult.OK)TransferData(fd.FileName,"sheet1",connString);pu
3、blicvoidTransferData(stringexcelFile,stringsheetName,stringconnectionString)DataSetds=newDataSet();try/获取全部数据stringstrConn="Provider=Microsoft.Jet.OLEDB.4.0;"+"DataSource="+excelFile+""+"ExtendedProperties=Excel8.0;"OleDbConnectionconn=newOleDbConnection(strCo
4、nn);conn.Open();stringstrExcel=""OleDbDataAdaptermyCommand=null;strExcel=string.Format("select*from0$",sheetName);myCommand=newOleDbDataAdapter(strExcel,strConn);myCommand.Fill(ds,sheetName);/如果目标表不存在则创建excel文件的第一行为列标题,从第二行开始全部都是数据记录stringstrSql=string.Format("ifobject_id(&a
5、mp;apos;0')isnullcreatetable0(",sheetName);/以sheetName为表名foreach(System.Data.DataColumncinds.Tables0.Columns)strSql+=string.Format("0varchar(255),",c.ColumnName);strSql=strSql.Trim(',')+")"using(System.Data.SqlClient.SqlConnectionSystem.Data.SqlClient.SqlCon
6、nection(connectionString)sqlconn.Open();System.Data.SqlClient.SqlCommandsqlconn.CreateCommand();command.CommandText=strSql;command.ExecuteNonQuery();sqlconn.Close();/sqlconncommand用bcp导入数据/excel文件中列的顺序必须和数据表的列顺序一致是从excel文件的第二行数据开始,不管数据表的结构是什么样的会插入到数据表的第一列字段中,第二列的数据插入到数据表的第二列字段中,以此类推,它本身不会去判断要插入的数据是对
7、应数据表中哪一个字段的using(System.Data.SqlClient.SqlBulkCopySystem.Data.SqlClient.SqlBulkCopy(connectionString)new因为数据导入时,反正就是第一列的数据bcpnewbcp.SqlRowsCopiedSystem.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);bcp.BatchSize=100;/每次传输的行数bcp.NotifyAfter=100;/进度提示的行数bcp.DestinationTableName=sheetName
8、;/bcp.WriteToServer(ds.Tables0);catch(Exceptionex)+=new目标表System.Windows.Forms.MessageBox.Show(ex.Message);/进度显示voidbcp_SqlRowsCopied(objectsender,/进度显示System.Data.SqlClient.SqlRowsCopiedEventArgse)this.Text=e.RowsCopied.ToString();this.Update();C#Excel导入数据库(二)方式二:本文先将Excel文件转换成DataTable,然后再循环将记录插入到
9、数据库表中,这种方式可以任由程序员来选择将哪列数据导入到数据表的哪个字段中DataTabletable=newDataTable();/数据绑定到datagridview1privatevoidbutton1_Click(objectsender,EventArgse)System.Windows.Forms.OpenFileDialogfd=newOpenFileDialog();if(fd.ShowDialog()=DialogResult.OK)stringfileName=fd.FileName;bind(fileName);privatevoidbind(stringfileName
10、)stringstrConn="Provider=Microsoft.Jet.OLEDB.4.0;"+"DataSource="+fileName+""+"ExtendedProperties='Excel8.0;HDR=Yes;IMEX=1'"OleDbDataAdapterda=newOleDbDataAdapter("SELECT*FROMSheet1$",strConn);DataSetds=newDataSet();tryda.Fill(ds);dt=ds.Tables
11、0;this.dataGridView1.DataSource=dt;catch(Exceptionerr)MessageBox.Show("操作失败!"+err.ToString();/将Datagridview1的记录插入到数据库privatevoidbutton2_Click(objectsender,EventArgse)if(dataGridView1.Rows.Count>0)DataRowdr=null;for(inti=0;i<dt.Rows.Count;i+)dr=dt.Rowsi;insertToSql(dr);MessageBox.Show("导入成功!");elseMessageBox.Show("没有数据!");privatevoidinsertToSql(DataRowdr)stringname=dr"姓名".ToString();stringage=dr"年龄".ToString();stringsql="insertintosheet1values('"
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 渔业养殖技术交流及产品销售合同
- 农业种植园区设施建设及维护合同
- 传媒行业媒体曝光及社会影响证明书(5篇)
- 网络游戏社区管理与维护方案
- 网络信息安全与数据保护策略及实施方案
- 特色养殖产业发展战略合作合同
- 品味建筑之美2025年考试试题及答案
- 2025届中考英语复习第一篇语言基础知识第1课七上Units1-5课后练习
- 市政学学科发展简史试题及答案
- 行政管理视角下市政学的理论评估试题及答案
- 归档文件目录
- 2022年四川省绵阳市中考英语试题及参考答案
- 防疫小组人员名单
- 眼部健康检测与分析课件
- 偏心块振动式土壤夯实机的结构设计说明
- 专业硕士学位论文修改报告(二)
- 苏州市建设工程造价计价解释
- 主题班会《坚定信念--放飞理想》
- 煤矿机电设备春季预防性检修计划
- S771(一) 水力循环澄清池
- 高密度电法探测及数据处理解释--答辩
评论
0/150
提交评论