• MVC3学习:将excel文件导入到sql server数据库


    思路:

    1、将excel文件导入到服务器中。

    2、读取excel文件,转换成dataset.

    3、循环将dataset数据插入到数据库中。

    本例子使用的表格为一个友情链接表F_Link(LinkId,LinkName,LinkUrl)

    使用的excel文件:

    准备工作做好后,就直接进入主题:

    一、view视图(视图名称为UploadFile,控制器为home)

    <script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
    <script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
    @using (Html.BeginForm("UploadFile", "home", FormMethod.Post, new { enctype = "multipart/form-data" }))
    {
        @Html.ValidationSummary(true)
         <input type="file" name="file" value="选择文件" />
         <input type="submit" id="submit" value="导入" />
    }

    二、控制器

    public ActionResult UploadFile()
            {
                //设置上传目录
                string path = Server.MapPath("~/Content/upload/");
                if (!Directory.Exists(path))
                    Directory.CreateDirectory(path);
                //判断是否已经选择上传文件
                HttpPostedFileBase file = Request.Files["file"];
                if (file != null && file.ContentLength > 0)
                {
                    string filenName = file.FileName;
                    string fileExt = Path.GetExtension(filenName).ToLower().Substring(1);
                    if (fileExt != "xls" && fileExt != "xlsx")
                    {
                        ModelState.AddModelError("", "您选择的不是Excel文件");
                        return View();
                    }
                    else
                    {
                        //上传文件
                        string filepath = path + filenName;
                        file.SaveAs(filepath);
                        //读取excel文件,转换成dataset
                        string strConn;
                        strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties=Excel 8.0;";
                        OleDbConnection conn = new OleDbConnection(strConn);
                        OleDbDataAdapter oada = new OleDbDataAdapter("select * from [Sheet1$]", strConn);
                        DataSet ds = new DataSet();
                        oada.Fill(ds);
                        //循环读取每一行,将数据插入到sql server数据库
                        foreach(DataRow row in ds.Tables[0].Rows)
                        {
                            F_link fl=new F_link();
                            fl.LinkName=row[0].ToString();
                            fl.LinkUrl=row[1].ToString();
                            db.F_link.AddObject(fl);
                            db.SaveChanges();
                        }
                        return RedirectToAction("index");
                    }
                }
                else
                {
                    ModelState.AddModelError("", "请选择文件");
                    return View();
                }
            }

    三、结果

  • 相关阅读:
    php记录代码执行时间
    TortoiseSVN教程级别指南
    有些 where 条件会导致索引无效
    mysql优化
    SQL优化方法
    mysql服务性能优化 my.cnf my.ini配置说明详解(16G内存)
    mysql慢查询设置
    javascript和php使用ajax通信传递JSON
    PHP导出大量数据到excel表格
    核心支付业务
  • 原文地址:https://www.cnblogs.com/denny402/p/3226912.html
Copyright © 2020-2023  润新知