zoukankan
html css js c++ java
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();
查看全文
相关阅读:
多进程要时刻当心的点
pairs和ipairs用的迭代器不一样
#pragma pack(push,1) & #pragma pack(pop)
负数取模不一定是正数
切记一定要get~
GAME有计时器,大厅没有计时器的原因
每天一个linux命令(1):ls命令
服务端发的某个short字段存到buf里是正值,存完在看就是0的问题
生成函数&多项式全家桶导学案
[Z]董的博客数据结构与算法汇总
原文地址:https://www.cnblogs.com/cnaspnet/p/863680.html
最新文章
在Delphi中捕获控制台程序的输出
CxGrid去掉表头
MYSQL数据库的查询优化技术(转)
Delphi中Owner和Parent的区别(转)
在Delphi中开发使用多显示器的应用程序
Dephi中获取webbrowser选取区域的html代码
Delphi Access violations 问题的解决方法
Delphi中Self和Sender的区别(转)
DELPHI的结构体,共用体和位域的等效实现
记者手记:我们从航天人身上学什么?
热门文章
中国Foursquare们路在何方
互联网产品设计(转)
公司经营 & 个人
今年能力提升重点
无题
跨越鸿沟(选读1)
工程师如何定位自己?
Which internship is better for a CS major, Facebook or Google? (From Quora)
图文:微博平台首席架构师杨卫华演讲
指针一定要做非空判断,非常重要!!!!!!!!
Copyright © 2011-2022 走看看