不知不觉博客园园林都两年多了,我是今年毕业的应届生,最近公司项目需要改动,很多的数据需要导入,很多的实体类需要些。考虑到这些问题自己写了两个winform版的小工具,一个是读取Execl数据导入数据库,另一个是自动生成实体类,以及增,删,改的方法。今天先分享Execl数据导入数据库。基本上没什么界面就两个按钮而已。一个是选择导入的文件,一个是导入数据库按钮。

首先我写了一个MSSQLAction的类,取数据的类,相当于三层里面的SqlHelper类,里面有两个方法

一个是准备读取数据前的命令配置

public static void PrepareCommand(SqlConnection conn, SqlCommand cmd, SqlTransaction trans, CommandType cmdType, string cmdText, params SqlParameter[] value)
{
  try
  {
    if (conn.State != ConnectionState.Open)
    {
      conn.Open();
    }
    cmd.Connection = conn;
    if (trans != null)
    {
      cmd.Transaction = trans;
    }
    cmd.CommandText = cmdText;
    cmd.CommandType = cmdType;
    if (value != null)
    {
      foreach (SqlParameter item in value)
      {
        cmd.Parameters.Add(item);
      }
    }
  }
  catch (Exception ex)
  {
    throw new Exception(ex.Message);
  }
}

另一个就是操作增,删,改的方法

public static int ExecuteNonQuery(string connString, CommandType cmdTyep, string cmdText, params SqlParameter[] value)
{
  using (SqlConnection conn = new SqlConnection(connString))
  {
    SqlCommand cmd = new SqlCommand();
    PrepareCommand(conn, cmd, null, cmdTyep, cmdText, value);
    int result = cmd.ExecuteNonQuery();
    cmd.Parameters.Clear();
    return result;
  }
}

取数据的类写好了,现在写Form的后台,一个四个方法:

一个是选择文件的事件,filepath 是一个全局变量

private void File_Click(object sender, EventArgs e)
{
  OpenFileDialog file = new OpenFileDialog();
  file.ShowDialog();
  filepath = file.FileName;
  label1.Text = file.FileName;
}

一个是获取Execl数据的方法

public List<System.Data.DataTable> GetExcelDatatable(string fileUrl)
{
  const string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";

  //建立连接
  OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
  try
  {
    //打开连接
    if (conn.State != ConnectionState.Open)
    {
      conn.Open();
    }

    List<System.Data.DataTable> list = new List<DataTable>();
    System.Data.DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
    //获取Excel的第一个Sheet名称
    for (int i = 0; i < schemaTable.Rows.Count; i++)
    {
      System.Data.DataTable dt = new DataTable();
      string sheetName = schemaTable.Rows[i]["TABLE_NAME"].ToString().Trim();
      string strSql = "select * from [" + sheetName + "]";
      OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
      DataSet ds = new DataSet();
      da.Fill(ds);
      dt = ds.Tables[0];
      list.Add(dt);
    }
    return list;
  }
  catch (Exception exc)
  {
    throw exc;
  }
  finally
  {
    conn.Close();
    conn.Dispose();
  }
}

一个是往数据库插入数据的方法

public int InsetData(System.Data.DataTable dt)
{
    int i = 0;
    foreach (DataRow dr in dt.Rows)
    {
      string findDate = dr[0].ToString().Trim() == "" ? null :
      Convert.ToDateTime(dr[0].ToString().Trim()).ToShortDateString().ToString();
      string date = Convert.ToDateTime(findDate).ToString("s");
      string resultDate = date.Substring(0, 10);
      string brand = dr[1].ToString().Trim() == "" ? null : dr[1].ToString().Trim();
      string storeName = dr[2].ToString().Trim() == "" ? null : dr[2].ToString().Trim();
      string type = storeName.Substring(0, 2);
      string city = dr[3].ToString().Trim() == "" ? null : dr[3].ToString().Trim();
      string throughTrain = dr[4].ToString().Trim() == "" ? "0" : dr[4].ToString().Trim();
      string showNumber = dr[5].ToString().Trim() == "" ? "0" : dr[5].ToString().Trim();
      string payNumber = dr[6].ToString().Trim() == "" ? "0" : dr[6].ToString().Trim();
      string freeNumber = dr[7].ToString().Trim() == "" ? "0" : dr[7].ToString().Trim();
      string drillShow = dr[8].ToString().Trim() == "" ? "0" : dr[8].ToString().Trim();
      string visitorsNumber = dr[9].ToString().Trim() == "" ? "0" : dr[9].ToString().Trim();
      string commission = dr[10].ToString().Trim() == "" ? "0" : dr[10].ToString().Trim();
      string activity = dr[11].ToString().Trim() == "" ? "0" : dr[11].ToString().Trim();
      string other = dr[12].ToString().Trim() == "" ? "0" : dr[12].ToString().Trim();

      string strConnection = "server=.;database=tests;Integrated Security=True";

      string strSql = "Insert into LemonFlagshipStore(Lemon1,Lemon2,Lemon3,Lemon4,Lemon5,Lemon6,Lemon7,Lemon8,Lemon9,Lemon10,Lemon11,Lemon12,Lemon13,Lemon14) Values ('" + brand + "','" + city + "','" + resultDate + "','" + storeName + "','" +       commission + "','" + activity + "','" +
      throughTrain + "','" + drillShow + "','" + other + "','" + freeNumber + "','" +
      payNumber + "','" + showNumber + "','" + visitorsNumber + "','" + type + "')";

      int result = MSSQLAction.ExecuteNonQuery(strConnection, CommandType.Text, strSql);
      i++;
    }
    return i;
}

最后就是一个简单点击导入数据的事件

private void Import_Click(object sender, EventArgs e)
{
  try
  {
    List<System.Data.DataTable> table = this.GetExcelDatatable(filepath);
    int listCount = 0;
    foreach (System.Data.DataTable dt in table)
    {
         int result = this.InsetData(dt);
      listCount += result;
    }
    MessageBox.Show("一共导入" + listCount + "数据", "导入成功");
  }
  catch (Exception ex)
  {
    MessageBox.Show("导入失败\r\n" + "失败原因为:\r\n" + ex, "提示");
  }
}

基本的代码实现就这么多,当然插入要使用此代码的话自己要把数据库链接和字符串和sql的表明字段改了。做完之后是不是觉得很简单,呵呵.....

另一个改天分享。如若需要源码:QQ 2212907254

读取Execl表 导入数据库的更多相关文章

  1. 读取Execl表数据 导入数据库

    不知不觉博客园园林都两年多了,我是今年毕业的应届生,最近公司项目需要改动,很多的数据需要导入,很多的实体类需要些.考虑到这些问题自己写了两个winform版的小工具,一个是读取Execl数据导入数据库 ...

  2. EXECL文件导入数据库

    Execl数据导入数据库: 注意事项:execl中的列名与列数要与数据库的列名和列数一致.值类型一致,列名不一致的话可在导入的时候,给字段起别名,确定保持一致 v 界面代码: <div> ...

  3. C# 读取Execl和Access数据库

    第一次写,请大家指教!!话不多说 直接走代码! /// <summary> /// 打开文件 /// </summary> /// <param name="s ...

  4. asp.net读取txt并导入数据库

    源地址:http://www.cnblogs.com/hfzsjz/p/3214649.html

  5. 将execl里的数据批量导入数据库

    本文将采用NPOI插件来读取execl文件里的数据,将数据加载到内存中的DataTable中 /// <summary> /// 将Excel转换为DataTable /// </s ...

  6. SpringMVC 实现POI读取Excle文件中数据导入数据库(上传)、导出数据库中数据到Excle文件中(下载)

    读取Excale表返回一个集合: package com.shiliu.game.utils; import java.io.File; import java.io.FileInputStream; ...

  7. 将数据库表导入到solr索引

    将数据库表导入到solr索引 编辑solrcofnig.xml添加处理器 <requestHandler name="/dataimport" class="org ...

  8. Oracle 基础 导入数据库 删除用户、删除表空间、删除表空间下所有表

    导入数据库 在cmd下用 imp导入  格式: imp userName/passWord file=bmp文件路径 ignore = y (忽略创建错误)full=y(导入文件中全部内容); 例: ...

  9. winform Execl数据 导入到数据库(SQL) 分类: WinForm C# 2014-05-09 20:52 191人阅读 评论(0) 收藏

    首先,看一下我的窗体设计: 要插入的Excel表: 编码 名称 联系人 电话 省市 备注 100 100线 张三 12345678910 北京 测试 101 101线 张三 12345678910 上 ...

随机推荐

  1. python的__init__几种方法总结

    参考 __init__() 这个方法一般用于初始化一个类 但是 当实例化一个类的时候, __init__并不是第一个被调用的, 第一个被调用的是__new__ #!/usr/bin/env pytho ...

  2. C++ STL Binary search详解

    一.解释 以前遇到二分的题目都是手动实现二分,不得不说错误比较多,关于返回值,关于区间的左闭右开等很容易出错,最近做题发现直接使用STL中的二分函数方便快捷还不会出错,不过对于没有接触过的同学,二分函 ...

  3. 双向循环链表(C语言描述)(四)

    下面以一个电子英汉词典程序(以下简称电子词典)为例,应用双向循环链表.分离数据结构,可以使逻辑代码独立于数据结构操作代码,程序结构更清晰,代码更简洁:电子词典的增.删.查.改操作分别对应于链表的插入. ...

  4. 再起航,我的学习笔记之JavaScript设计模式05(简单工程模式)

    我的学习笔记是根据我的学习情况来定期更新的,预计2-3天更新一章,主要是给大家分享一下,我所学到的知识,如果有什么错误请在评论中指点出来,我一定虚心接受,那么废话不多说开始我们今天的学习分享吧! 前几 ...

  5. JS的事件多次触发,只执行最后一次

    有时候我们在JS编程的过程中经常遇到一个问题就是事件频繁高速被触发,利用计时器来控制频率又会丢弃掉有用的事件,我们只是想让程序执行最后一次的事件,那么就可以用如下方法解决问题 //写在事件外边,防止被 ...

  6. 7种方法解决移动端Retina屏幕1px边框问题

    在Reina(视网膜)屏幕的手机上,使用CSS设置的1px的边框实际会比视觉稿粗很多.在之前的项目中,UI告诉我说我们移动项目中的边框全部都变粗了,UI把他的设计稿跟我的屏幕截图跟我看,居然真的不一样 ...

  7. SolrCloud(一)搭建Zookeeper

    搭建Zookeeper 三台服务器: AMouse: 192.168.3.201 BCattle : 192.168.3.202 Ctiger   : 192.168.3.203 一 下载Zookee ...

  8. Python web框架总结

    web框架总结 前提 一个web框架需要包含的组件或者功能有: router orm request and response cookies and session template engine ...

  9. Shell - 简明Shell编程

    本文是对Shell脚本编程的总结和回顾,所有涉及的脚本均已做了基本的调试和验证. [toc] 测试环境信息 [root@CentOS7 ~]# uname -a Linux CentOS7 3.10. ...

  10. Lenovo T440p 外放没有声音

    背景:Lenovo T440p,今天突然想听会歌 外放竟然没声音,fuck!!! 任务栏声音图标也没有静音标志. 驱动出问题了?检查下驱动,正常. 找了耳机试下,正常,看来驱动真的没问题. 喇叭坏了? ...