public DataSet GetXlsContent(string SheetName, string FileName)
{
tbDataBaseModel tbdbModel = new tbDataBaseModel();
DataSet ds = new DataSet();
//string Path = File.Replace(@"//", @"/");
//string FromFile = FileName.Substring(FileName.LastIndexOf('//') + 1);
try
{
string ExcelCmd = "";
string olestr = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + FileName + ";" + "Extended Properties=Excel 8.0;";
OleDbConnection ODC = new OleDbConnection(olestr);
ODC.Open();
OleDbDataAdapter odda = null;
ExcelCmd = string.Format(@"SELECT * FROM [{0}$]", SheetName);
odda = new OleDbDataAdapter(ExcelCmd, olestr);
odda.Fill(ds, SheetName);
if (ds != null && ds.Tables[0].Rows.Count > 0)
{
return ds;
}
else
{
Common.JScript.Alert("空数据!");
return null;
}
}
catch
{
return null;
}
}
然后从dataset里将数据通过SqlBulkCopy 类提供的方法(请看msdn详述)导入数据库,经过测试目前导入5W条数据只要4秒到6秒,网络上说只要4.5,我想这些和网速以及服务器的性能有很大的关系
public bool InserModelRows(DataSet ds)
{
SqlBulkCopy sbc = new SqlBulkCopy(SQLHelp.ConnectionString, SqlBulkCopyOptions.FireTriggers);第二个参数有很多枚举,具体请看msdn
sbc.DestinationTableName = "tbStudent"; 这里指定了目标数据库的目标表
sbc.ColumnMappings.Add("学号", "sStudentNumberID_FK");
sbc.ColumnMappings.Add("姓名", "sStudentName");
sbc.ColumnMappings.Add("金额", "mMoney");
sbc.ColumnMappings.Add("项目", "iItemID_FK");
sbc.ColumnMappings.Add("出帐日期", "dTime");
sbc.ColumnMappings.Add("银行帐号", "sCreditCard");以上几行前面的汉字是EXCEL的字段名,第二个是目标表的字段名,要一一对应
try
{
sbc.WriteToServer(ds.Tables[0]);这里是将ds里的指定的表的数据导入目标表,这里的目标表是tbStudent
return true;
}
catch
{
return false;
}
}
恩,这样就可以了,当然数据库字段类型的定义得确定,以我的测试,EXCEL里的文本类型,在SQLSERVER里相对应的是nvarchar(255)类型,数字式float类型,如果是主键的话,用int型也可以