Csharp/C#教程:C#实现Excel表数据导入Sql Server数据库中的方法分享

本文实例讲述了C#实现Excel表数据导入SqlServer数据库中的方法。分享给大家供大家参考,具体如下:

Excel表数据导入SqlServer数据库的方法很多,这里只是介绍了其中一种:

1、首先,我们要先在test数据库中新建一个my_test表,该表具有三个字段tidint类型,tnamenvarchar类型,ttnvarchar类型
(注意:my_test表中的数据类型必须与Excel中相应字段的类型一致)

2、我们用SELECT*FROM OPENROWSET(‘Microsoft.Jet.OLEDB.4.0′,’Excel 5.0;DatabASE=[Excel表.xsl文件的路径];HDR=YES;IMEX=1’,Sheet1来读取Excel表中的数据,读出来的数据跟从数据库中的表读出的数据是一样,也包括字段名和数据。当然我们也可以用字段名列表来获取Excel表中的部门数据。SELECT字段1,字段2,字段3[…]FROM OPENROWSET(‘Microsoft.Jet.OLEDB.4.0′,’Excel 5.0;DatabASE=[Excel表.xsl文件的路径];HDR=YES;IMEX=1’,Sheet1

注意:HDR=Yes,这代表第一行是标题,不做为数据使用;IMEX(IMportEXportmode)设置
  IMEX有三种模式:
  0isExportmode
  1isImportmode
  2isLinkedmode(fullupdatecapabilities)
  我这里特别要说明的就是IMEX参数了,因为不同的模式代表著不同的读写行为:
  当IMEX=0时为“汇出模式”,这个模式开启的Excel档案只能用来做“写入”用途。
  当IMEX=1时为“汇入模式”,这个模式开启的Excel档案只能用来做“读取”用途。
  当IMEX=2时为“连结模式”,这个模式开启的Excel档案可同时支援“读取”与“写入”用途。
意义如下:
0—输出模式;
1—输入模式;
2—-链接模式(完全更新能力)

3、Excel中第一行是定义的是列名,从第2行开始才是数据。通过Sql语句从Excel中读取到的数据也是从第二行开始的,二列名变成了字段名。如果你的第一行有定义列名,那么从Excel中获取的数据的各个字段的名称就是Excel中的列名。如:从test.xlssheet表中获取的数据的字段名分别是编号姓名备注。如果你定义的Excel表的第一行没有定义列名,那么获取后数据的字段名分别是F1、F2、F3…以此类推。如果你只是要获取Excel表中部分列的数据,那么你可以就要用到上面的内容。

4、在VS中新建一个web窗体(test.aspx,注:winform窗体也可以),往其中添加一个Button控件,一点击该按钮就执行导入。双击该按钮,定义事件处理函数。test.aspx.cs中的代码如下:

usingSystem; usingSystem.Data; usingSystem.Configuration; usingSystem.Collections; usingSystem.Web; usingSystem.Web.Security; usingSystem.Web.UI; usingSystem.Web.UI.WebControls; usingSystem.Web.UI.WebControls.WebParts; usingSystem.Web.UI.HtmlControls; usingSystem.Data.SqlClient; publicpartialclassadmin_test:System.Web.UI.Page { protectedvoidPage_Load(objectsender,EventArgse) { } publicSqlConnectioncon() { returnnewSqlConnection("server=localhost;uid=test;pwd=test;database=test"); //这里的uid=test中的test必须是SystemAdministrtor,否则会出错 } protectedvoidButton1_Click1(objectsender,EventArgse) { SqlConnectionmycon=con(); stringsqlstr="insertintomy_testselect编号,姓名,备注fromOPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel5.0;HDR=YES;DATABASE=e:\test.xls',sheet1$)"; /*这里可以用*代替编号,姓名,备注,这些表示excel中的列名*/ SqlCommandcmd=newSqlCommand(sqlstr,mycon); mycon.Open(); cmd.ExecuteNonQuery(); mycon.Close(); } }

执行上面的代码可能会出现下面的问题:

SQLServer阻止了对组件’AdHocDistributedQueries’的STATEMENT’OpenRowset/OpenDatasource’的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用sp_configure启用’AdHocDistributedQueries’。有关启用’AdHocDistributedQueries’的详细信息,请参阅SQLServer联机丛书中的”外围应用配置器”。

解决办法:

/*启用AdHocDistributedQueries:*/ execsp_configure'showadvancedoptions',1 reconfigure execsp_configure'AdHocDistributedQueries',1 reconfigure /*使用完成后,关闭AdHocDistributedQueries:*/ execsp_configure'AdHocDistributedQueries',0 reconfigure execsp_configure'showadvancedoptions',0 reconfigure

更多关于C#相关内容感兴趣的读者可查看本站专题:《C#操作Excel技巧上述就是C#学习教程:C#实现Excel表数据导入Sql Server数据库中的方法分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/907828.html

(0)
上一篇 2021年10月25日
下一篇 2021年10月25日

精彩推荐