欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C#实现Excel表数据导入Sql Server数据库中的方法

程序员文章站 2023-12-03 17:09:22
本文实例讲述了c#实现excel表数据导入sql server数据库中的方法。分享给大家供大家参考,具体如下: excel表数据导入sql server数据库的方法很多,...

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

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

1、首先,我们要先在test数据库中新建一个my_test表,该表具有三个字段tid int类型, tname nvarchar类型, tt nvarchar类型
(注意: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 ( import export mode )设置
  imex 有三种模式:
  0 is export mode
  1 is import mode
  2 is linked mode (full update capabilities)
  我这里特别要说明的就是 imex 参数了,因为不同的模式代表著不同的读写行为:
  当 imex=0 时为“汇出模式”,这个模式开启的 excel 档案只能用来做“写入”用途。
  当 imex=1 时为“汇入模式”,这个模式开启的 excel 档案只能用来做“读取”用途。
  当 imex=2 时为“连结模式”,这个模式开启的 excel 档案可同时支援“读取”与“写入”用途。
意义如下:
0 ---输出模式;
1---输入模式;
2----链接模式(完全更新能力)

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

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

using system;
using system.data;
using system.configuration;
using system.collections;
using system.web;
using system.web.security;
using system.web.ui;
using system.web.ui.webcontrols;
using system.web.ui.webcontrols.webparts;
using system.web.ui.htmlcontrols;
using system.data.sqlclient;
public partial class admin_test : system.web.ui.page
{
  protected void page_load(object sender, eventargs e)
  {
  }
  public sqlconnection con()
  {
    return new sqlconnection("server=localhost;uid=test;pwd=test;database=test");
    //这里的uid=test中的test必须是system administrtor, 否则会出错
  }
  protected void button1_click1(object sender, eventargs e)
  {
    sqlconnection mycon = con();
    string sqlstr = "insert into my_test select 编号, 姓名, 备注 from openrowset('microsoft.jet.oledb.4.0','excel 5.0;hdr=yes;database=e:\\test.xls',sheet1$)";
/*这里可以用 * 代替 编号, 姓名, 备注,这些表示excel中的列名  */
    sqlcommand cmd = new sqlcommand(sqlstr, mycon);
    mycon.open();
    cmd.executenonquery();
    mycon.close();
  }
}

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

sql server 阻止了对组件 'ad hoc distributed queries' 的 statement'openrowset/opendatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'ad hoc distributed queries'。有关启用 'ad hoc distributed queries' 的详细信息,请参阅 sql server 联机丛书中的 "外围应用配置器"。

解决办法:

/*启用ad hoc distributed queries:*/
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'ad hoc distributed queries',1
reconfigure
 
/*使用完成后,关闭ad hoc distributed queries:*/
exec sp_configure 'ad hoc distributed queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure

更多关于c#相关内容感兴趣的读者可查看本站专题:《c#操作excel技巧总结》、《c#程序设计之线程使用技巧总结》、《c#中xml文件操作技巧汇总》、《c#常见控件用法教程》、《winform控件用法总结》、《c#数据结构与算法教程》、《c#数组操作技巧总结》及《c#面向对象程序设计入门教程

希望本文所述对大家c#程序设计有所帮助。