C#把Excel导入数据库的两种方法

上传人:suij****uang 文档编号:173925497 上传时间:2022-12-13 格式:DOCX 页数:3 大小:13.75KB
收藏 版权申诉 举报 下载
C#把Excel导入数据库的两种方法_第1页
第1页 / 共3页
C#把Excel导入数据库的两种方法_第2页
第2页 / 共3页
C#把Excel导入数据库的两种方法_第3页
第3页 / 共3页
资源描述:

《C#把Excel导入数据库的两种方法》由会员分享,可在线阅读,更多相关《C#把Excel导入数据库的两种方法(3页珍藏版)》请在装配图网上搜索。

1、式一:实现在c#中可高效的将excel数据导入到sqlserver数据库中,很多人通过循环来拼接sql,这样做不但容易出错而且效率低下,最好的办法是使用bcp,也就是System.Data.SqlClient.SqlBulkCopy类来实现。usingSystem;usingSystem.Data;usingSystem.Windows.Forms;usingSystem.Data.OleDb;namespaceWindowsApplication2publicpartialclassForm1:FormpublicForm1()InitializeComponent();privatevoi

2、dbutton1_Click(objectsender,EventArgse)/测试,将excel中的sheetl导入到sqlserver中stringconnStringserver=localhost;uid=sa;pwd=sqlgis;database=master;newsheetl,System.Windows.Forms.OpenFileDialogfdOpenFileDialog();if(fd.ShowDialog()=DialogResult.OK)TransferData(fd.FileName,connString);publicvoidTransferData(stri

3、ngexcelFile,stringsheetName,stringconnectionString)DataSetds=newDataSet();try/获取全部数据stringstrConn=Provider=Microsoft.Jet.OLEDB.4.0;+DataSource=+excelFile+;+ExtendedProperties=Excel8.0;OleDbConnectionconn=newOleDbConnection(strConn);conn.Open();stringstrExcel=;OleDbDataAdaptermyCommand=null;strExcel=

4、string.Format(select*from0$,sheetName);myCommand=newOleDbDataAdapter(strExcel,strConn);myCommand.Fill(ds,sheetName);/如果目标表不存在则创建excel文件的第一行为列标题,从第二行开始全部都是数据记录stringstrSql=string.Format(ifobject_id('0')isnullcreatetable0(,sheetName);/以sheetName为表名foreach(System.Data.DataColumncinds.Tables0.

5、Columns)strSql+=string.Format(0varchar(255),c.ColumnName);strSql=strSql.Trim(,)+);using(System.Data.SqlClient.SqlConnectionsqlconn=newSystem.Data.SqlClient.SqlConnection(connectionString)sqlconn.Open();System.Data.SqlClient.SqlCommandcommand=sqlconn.CreateCommand();command.CommandText=strSql;command

6、.ExecuteNonQuery();sqlconn.Close();/用bcp导入数据/excel文件中列的顺序必须和数据表的列顺序一致,因为数据导入时,是从excel文件的第二行数据开始,不管数据表的结构是什么样的,反正就是第一列的数据会插入到数据表的第一列字段中,第二列的数据插入到数据表的第二列字段中,以此类推,它本身不会去判断要插入的数据是对应数据表中哪一个字段的using(System.Data.SqlClient.SqlBulkCopybcp=newSystem.Data.SqlClient.SqlBulkCopy(connectionString)bcp.SqlRowsCopie

7、d+=newSystem.Data.SqlClient.SqlRowsCopiedEventHandler(bcp_SqlRowsCopied);bcp.BatchSize=100;/每次传输的行数bcp.NotifyAfter=100;/进度提示的行bcp.DestinationTableName=sheetName;/目标表bcp.WriteToServer(ds.Tables0);catch(Exceptionex)System.Windows.Forms.MessageBox.Show(ex.Message)/进度显示voidbcp_SqlRowsCopied(objectsender

8、,System.Data.SqlClient.SqlRowsCopiedEventArgse)this.Text=e.RowsCopied.ToString();this.Update();C#Excel导入数据库(二)方式二:本文先将Excel文件转换成DataTable,然后再循环将记录插入到数据库表中,这种方式可以任由程序员来选择将哪列数据导入到数据表的哪个字段中DataTabletable=newDataTable();/数据绑定到datagridviewlprivatevoidbutton1_Click(objectsender,EventArgse)System.Windows.F

9、orms.OpenFileDialogfd=newOpenFileDialog();if(fd.ShowDialog()=DialogResult.OK)stringfileName=fd.FileName;bind(fileName);privatevoidbind(stringfileName)stringstrConn=Provider=Microsoft.Jet.OLEDB.4.0;+DataSource=+fileName+;+ExtendedProperties=Excel8.0;HDR=Yes;IMEX=1;OleDbDataAdapterda=newOleDbDataAdapt

10、er(SELECT*FROMSheet1$,strConn);DataSetds=newDataSet();tryda.Fill(ds);dt=ds.Tables0;this.dataGridView1.DataSource=dt;catch(Exceptionerr)MessageBox.Show(操作失败!+err.ToString();/将Datagridviewl的记录插入到数据库privatevoidbutton2_Click(objectsender,EventArgse)if(dataGridViewl.Rows.Count0)DataRowdr=null;for(inti=0;

11、idt.Rows.Count;i+)dr=dt.Rowsi;insertToSql(dr);MessageBox.Show(导入成功!);elseMessageBox.Show(没有数据!);privatevoidinsertToSql(DataRowdr)stringname二dr姓名.ToString();stringage=dr年龄.ToString();stringsql=insertintosheetlvalues(+name+,+age+);SqlConnectionconn=newSqlConnection();SqlCommandcmd=newSqlCommand(sql,conn);conn.Open();cmd.ExecuteNonQuery();conn.Close();

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!