EXCEL导入GridView,然后再汇入数据库.

原文:EXCEL导入GridView,然后再汇入数据库.

近日项目中有一个多笔料号要输入,我做了一个用javascript复制输入框的功能,可以输入多笔料号。

但是使用者反馈,料号太多,可能几百个料号在EXCEL文件里,这样输入很慢,需要增加功能。于是想到了SQLSERVER导入EXCEL的功能。

declare @strExcelName varchar(50)

set @strExcelName=‘c:\sl.xls‘

exec(‘select * into ##tmp from openrowset(‘‘MICROSOFT.JET.OLEDB.4.0‘‘,‘‘Excel 8.0;HDR=No;IMEX=1;DATABASE=‘+@strExcelName+‘‘‘,[Sheet1$]) ‘)

select * from ##tmp

这样是可以导入数据,但是问题来了。我的数据库服务器和运行程序服务器不在同一服务器,无法导入(可能有方法,但是项目紧,没时间去探索),于是想到另外一个方法:先上传EXCEL文件,然后读入DATASET放入GridView,然后从GridView提交到数据库,这样就没有问题。

文件上传控件:<input id="myFile" runat="server" type="file" />

Form里不需要enctype="multipart/form-data"

文件上传代码:

            if (myFile.PostedFile.FileName != "")

            {

                //上传文件的绝对路径

                string sFile = myFile.PostedFile.FileName;

                //获取文件全名

                sFile = sFile.Substring(sFile.LastIndexOf("\\") + 1);

                //获取后缀名

                sFile = sFile.Substring(sFile.LastIndexOf("."));

                if (sFile.ToLower() != ".xls")

                {

                    Response.Write("请选择Excel文件!");

                    Response.End();

                }

                //为了防止重名,获得日期为文件名年月日时分秒毫秒

                string datatime = System.DateTime.Now.ToString("yyyMMddHHmmssffff");

                //上传后文件的新名

                sFile = datatime + sFile;

                //AppDomain.CurrentDomain.BaseDirectory.ToString() 获取此项目的根目录

                //sPath 获取上传后的路径

                string sPath = AppDomain.CurrentDomain.BaseDirectory.ToString() + "ExcelFiles\\" + sFile;

                //上传文件

                myFile.PostedFile.SaveAs(sPath);

                this.myGridView.DataSource = GetExcelContent(sPath);

                this.myGridView.DataBind();

            }

读取EXCEL到DATASET代码:

        private DataSet GetExcelContent(string filepath)

        {

            string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filepath + ";Extended Properties=‘Excel 8.0;HDR=No;IMEX=1‘";

            System.Data.OleDb.OleDbConnection myConn = new System.Data.OleDb.OleDbConnection(strCon);

            string strCom = "SELECT F1 as resno,F2 as resname FROM [Sheet1$]";

            myConn.Open();

            System.Data.OleDb.OleDbDataAdapter myCommand = new System.Data.OleDb.OleDbDataAdapter(strCom, myConn);

            //创建一个DataSet对象

            DataSet myDataSet = new DataSet();

            //得到自己的DataSet对象

            myCommand.Fill(myDataSet);

            //关闭此数据链接

            myConn.Close();

            return myDataSet;

        }

最后是数据提交到数据库代码:

            string stresno = "";

            string stresname = "";

            foreach (GridViewRow row in this.myGridView.Rows)

            {

                Label txtesno = (Label)row.FindControl("labresno");

                stresno += txtesno.Text.ToString().Trim().Replace("‘", "‘‘") + ";";

                Label txtresname = (Label)row.FindControl("labresname");

                stresname += txtresname.Text.ToString().Trim().Replace("‘", "‘‘") + ";";

            }

            Response.Write(stresno + "<br/>" + stresname);

            Response.End();

时间: 2024-11-05 14:37:16

EXCEL导入GridView,然后再汇入数据库.的相关文章

MVC3 Excel导入数据到sql Server数据库

MVC Excel导入到数据库,我们客户有一个固定的Excel,每个月都让我手动录入到库内(一开始不会SQL的导入)一两次我还好,蛮乐意的后来多了,我就使用了SQL自带的导入,可是每个月都这样,就太恶心了,为了凸显我是一个程序员,我跟项目经理提出,做一个页面上传Excel文件的页面,然后保存到数据库,让客户上传,天天上传都可以,不要每个月找我一次,而且客户还是个女的,最让我不开心的是她还那么土,然后项目经理说既然是你想出来的,那么你就自己写,我化石了,则个则.............ge.我是一

Excel 导入到Datatable 中,再使用常规方法写入数据库

首先呢?要看你的电脑的office版本,我的是office 2013 .为了使用oledb程序,需要安装一个引擎.名字为AccessDatabaseEngine.exe.这里不过多介绍了哦.它的数据库连接字符串是"Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'" 所以,我们是使用ole来读取excel的. 1 excel 的文件内容:

C#将数据库导出成Excel,再从Excel导入到数据库中。

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.SqlClient; using System.IO; namespace CindyDatabaseProcess { class Program { static void Main(string[] args) { System.Data.DataTable dt1 = null; S

.Net core 使用NPOI 直接导入Excel到数据库(即不先将Excel保存到服务器再读取文件到数据库)

原文:.Net core 使用NPOI 直接导入Excel到数据库(即不先将Excel保存到服务器再读取文件到数据库) 1 /// <summary> 2 /// 导入信息 3 /// </summary> 4 /// <param name="file"></param> 5 /// <returns></returns> 6 /// /Public/PublicPool/ImportCustomer 7 pub

excel导入到数据库的异常处理

excel导入到数据库,这个是经常发生的,今天就碰到了一个非常郁闷的事情,在导入到oracle数据的时候,总是出现ORA-01756: 引号内的字符串没有正确结束,认真的排插了数据当中可能出现的错误,明明感觉是某个不可见字符或者是某个很细小的字符造成的,后来终于找到诀窍了,要把字符中的空格,逗号(全角半角),引号(全角半角),斜杠换行符等都清楚干净再去导入.

POI实现Excel导入数据库数据

POI实现Excel导入数据库数据 首先看一下我们导入的数据Excel中的数据格式是什么 ?上面是我们的一个数据导入时的模板信息,我们需要按照这样过的格式导入数据库数据. 针对这样的数据格式可以通过ReadExcelUtils的工具类去读取到 ReadExcelUtils readExcelUtils = new ReadExcelUtils(file.getInputStream(),fileName); 通过上述代码我们可以获取到ReadExcelUtils对象,再调用其readExcelL

Java实现Excel导入数据库,数据库中的数据导入到Excel

实现的功能: Java实现Excel导入数据库,如果存在就更新 数据库中的数据导入到Excel 1.添加jxl.jar mysql-connector-java.1.7-bin.jar包到项目的lib目录下­ 2.Excel文件目录:D://book.xls 3.数据库名:javenforexcel 4.表名:stu 5.编写类:连接mysql的字符串方法.插入的方法.实体类­­ 表结构如下 : 连接数据库的工具类 package com.javen.db; import java.sql.Co

将Excel [导入到数据库] or 将数据 [导入到Excel]

将Excel导入到数据库实现如下: 前台代码: @model IEnumerable<Model.Student> @{ Layout = null; } <!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width" /> <title>Index</title> <script

Silverlight将Excel导入到SQLserver数据库

最近纠结于读取Excel模板数据,将数据导入SQLServer的Silverlight实现,本文将实现代码贴出,作为一个简单的例子,方便各位: 1.先设计前台界面新建Silverlight5.0应用程序,出现MainPage.xaml,代码如下所示: <UserControl x:Class="Excel导入SQLServer数据库.MainPage" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/present