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

作者:aparche 时间:2024-01-19 01:19:01 

本文实例讲述了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,Sql,Server
0
投稿

猜你喜欢

  • 举例讲解Python中的死锁、可重入锁和互斥锁

    2023-12-21 07:35:03
  • Get方法和Post方法的区别深入理解

    2023-12-09 11:42:18
  • python光学仿真实现光线追迹之空间关系

    2023-10-29 01:48:42
  • Python 函数那不为人知的一面

    2022-09-24 10:03:31
  • Go语言实现简单的一个静态WEB服务器

    2024-04-28 09:12:56
  • 远程过程调用RPC基本概念及实现原理

    2022-09-24 06:45:30
  • Python中的配对函数zip()解读

    2021-04-14 20:54:33
  • Python实现微信中找回好友、群聊用户撤回的消息功能示例

    2022-02-04 02:51:02
  • Go语言Zap日志库使用教程

    2024-05-05 09:27:11
  • python3 使用ssh隧道连接mysql的操作

    2023-09-01 19:15:11
  • PHP iconv 解决utf-8和gb2312编码转换问题

    2024-04-29 13:56:58
  • 保安的故事

    2009-12-28 13:02:00
  • 图文详解mysql5.7安装教程

    2024-01-26 10:47:03
  • Python爬虫采集微博视频数据

    2023-08-11 16:01:03
  • Python在游戏中的热更新实现

    2022-04-05 14:10:15
  • 使用Perl DBI操作MySQL的一些建议

    2024-01-16 11:20:55
  • ASP分页和日期格式化为RFC822格式的办法

    2008-11-21 15:46:00
  • 不得不承认:韩国的 Web 设计很唯美

    2009-05-13 13:26:00
  • 浅谈numpy中np.array()与np.asarray的区别以及.tolist

    2022-06-06 12:32:10
  • python实现超级玛丽游戏

    2023-10-02 20:19:28
  • asp之家 网络编程 m.aspxhome.com