注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

零售创新,创新那些事儿,SPSS,VBA

零售创新

 
 
 

日志

 
 
关于我

新浪微博,零售创新 研究经理,数据分析师 希望和市场研究和零售业的同事共同进步! 本博客发表的都是免费或试用的资料,如果有版权问题请发邮件wangli12a@163.com联系删除。 spss excel vba blog

网易考拉推荐

Excel导入到MSSQL Server  

2012-04-19 16:22:07|  分类: VB和VBA知识 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

Excel导入到MSSQL Server
因项目需要,将Excel批量数据导入SQL Server

public DataSet ExecleDs(string filenameurl, string table)
  {
      string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + filenameurl + ";Extended Properties='Excel 8.0; HDR=YES; IMEX=1'";
      OleDbConnection conn = new OleDbConnection(strConn);
      conn.Open();
      DataSet ds = new DataSet();
      OleDbDataAdapter odda = new OleDbDataAdapter("select * from [Sheet1$]", conn);
      odda.Fill(ds, table);
      return ds;
  }

  protected void Button1_Click(object sender, EventArgs e)
  {
      if (FileUpload1.HasFile == false)//HasFile用来检查FileUpload是否有指定文件
      {
          Response.Write("<script>alert('请您选择Excel文件')</script> ");
          return;//当无文件时,返回
      }
      string IsXls = System.IO.Path.GetExtension(FileUpload1.FileName).ToString().ToLower();//System.IO.Path.GetExtension获得文件的扩展名
      if (IsXls != ".xls")
      {
          Response.Write("<script>alert('只可以选择Excel文件')</script>");
          return;//当选择的不是Excel文件时,返回
      }
      SqlConnection cn = new SqlConnection(strConn);
      cn.Open();
      string filename = DateTime.Now.ToString("yyyymmddhhMMss") + FileUpload1.FileName;              //获取Execle文件名  DateTime日期函数
      string savePath = Server.MapPath(("~\\files\") + filename);//Server.MapPath 获得虚拟服务器相对路径
      FileUpload1.SaveAs(savePath);                        //SaveAs 将上传的文件内容保存在服务器上
      DataSet ds = ExecleDs(savePath, filename);           //调用自定义方法
      DataRow[] dr = ds.Tables[0].Select();            //定义一个DataRow数组
      int rowsnum = ds.Tables[0].Rows.Count;
      if (rowsnum == 0)
      {
          Response.Write("<script>alert('Excel表为空表,无数据!')</script>");   //当Excel表为空时,对用户进行提示
      }
      else
      {
          for (int i = 0; i < dr.Length; i++)
          {
              string strCourseId = dr[i]["课程号"].ToString();//日期 excel列名【名称不能变,否则就会出错】
              string strTerm = dr[i]["学期"].ToString();//编号 列名 以下类似
              string strCourseOrder = dr[i]["课序号"].ToString();
              string strStuId = dr[i]["学号"].ToString();
              string sqlcheck = "select count(*) from Course_Student where CourseId='" + strCourseId + "'And Term ='" + strTerm + "' And CourseOrder ='" + strCourseOrder + "' And StudentId ='" + strStuId + "'";  //检查该课堂是否存在
              SqlCommand sqlcmd = new SqlCommand(sqlcheck, cn);
              int count = Convert.ToInt32(sqlcmd.ExecuteScalar());
              if (count < 1)
              {
                  string insertstr = "insert into Course_Student(CourseId,Term,CourseOrder,StudentId) values('" + strCourseId + "','" + strTerm + "','" + strCourseOrder + "','" + strStuId + "')";

                  SqlCommand cmd = new SqlCommand(insertstr, cn);
                  try
                  {
                      cmd.ExecuteNonQuery();
                      BindGridView();
                  }
                  catch (MembershipCreateUserException ex)       //捕捉异常
                  {
                      Response.Write("<script>alert('导入内容:" + ex.Message + "')</script>");
                  }
              }
              else
              {
                  Response.Write("<script>alert('内容重复!禁止导入');location='plCourse.aspx'</script></script> ");
                  continue;
              }
          }
          Response.Write("<script>alert('Excle表导入成功!');</script>");
      }

      cn.Close();
  }

  评论这张
 
阅读(1297)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017