将Excel数据导入数据库

时间:2024-04-15 17:05:03

Excel如下,这页工作表名叫“线路”将Excel数据导入数据库

数据库表如下

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data;
using System.Data.OleDb;
using System.Configuration;
using System.Data.SqlClient; namespace insertData
{
class FileSvr
{
/// <summary>
/// 获取DataRow的真实长度
/// </summary>
/// <param name="dr">DataRow</param>
/// <returns>真实长度</returns>
public int getRowLen(DataRow dr)
{
int i = ;
for (; i < dr.ItemArray.Length; i++)
if (dr[i].ToString().Trim() == "") break;
return i;
}
/// <summary>
/// //Excel指定的工作表数据导入Datable
/// </summary>
/// <param name="fileUrl">Excel路径</param>
/// <param name="sheetName">工作表名</param>
/// <returns></returns>
public DataTable getExcelDatatable(string fileUrl, string sheetName)//Excel指定的工作表数据导入Datable
{
//支持.xls和.xlsx,即包括office2010等版本的 HDR=Yes代表第一行是标题,不是数据;
const string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; DataTable dt = null;
//建立连接
OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl));
try
{
//打开连接
if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
{
conn.Open();
} //查询sheet中的数据
string strSql = "select * from [" + sheetName + "$]";
OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
DataSet ds = new DataSet();
da.Fill(ds);
dt = ds.Tables[];
return dt;
}
catch (Exception exc)
{
throw exc;
}
finally
{
conn.Close();
conn.Dispose();
}
}
public void InsertRoute(DataTable dt, string strConnection,int dir)//从DataTable导入数据到数据库
{
int retVal = ;
int count0 = ;
int count = ;
int routeNo;
SqlConnection conn = new SqlConnection(strConnection);
conn.Open();
string strSql;
SqlCommand sqlCmd = new SqlCommand();
sqlCmd.Connection = conn;
sqlCmd.Parameters.Add("@编号", System.Data.SqlDbType.Int, );
sqlCmd.Parameters.Add("@线路号", System.Data.SqlDbType.Int, );
sqlCmd.Parameters.Add("@行向", System.Data.SqlDbType.Int, );
sqlCmd.Parameters.Add("@线路名称", System.Data.SqlDbType.NVarChar, );
sqlCmd.Parameters.Add("@始发站点", System.Data.SqlDbType.NVarChar, );
sqlCmd.Parameters.Add("@开往方向", System.Data.SqlDbType.NVarChar, );
sqlCmd.Parameters.Add("@更新时间", System.Data.SqlDbType.DateTime, );
foreach (DataRow dr in dt.Rows)//遍历行数据
{
strSql= "update 线路 set 线路号=@线路号, 行向=@行向, 线路名称=@线路名称, 始发站点=@始发站点, 开往方向=@开往方向,更新时间=@更新时间 where 编号=@编号";
sqlCmd.CommandText = strSql;
routeNo =Convert.ToInt32(dr[].ToString().Trim());
sqlCmd.Parameters["@编号"].Value = routeNo+dir*;
sqlCmd.Parameters["@线路号"].Value=routeNo;
sqlCmd.Parameters["@行向"].Value=dir;
sqlCmd.Parameters["@线路名称"].Value=routeNo+"路";
sqlCmd.Parameters["@始发站点"].Value=dr[].ToString();
sqlCmd.Parameters["@开往方向"].Value=dr[getRowLen(dr)-].ToString();
sqlCmd.Parameters["@更新时间"].Value = DateTime.Now;
retVal = sqlCmd.ExecuteNonQuery();
if (retVal == )
{
strSql = @"insert into 线路( 编号, 线路号, 行向, 线路名称, 始发站点, 开往方向, 更新时间) values(@编号,@线路号,@行向,@线路名称,@始发站点,@开往方向,@更新时间)";
sqlCmd.CommandText = strSql;
retVal = sqlCmd.ExecuteNonQuery();
count++;
Console.WriteLine("插入线路{0}成功!", routeNo);
}
else
{
count0++;
Console.WriteLine("更新线路{0}成功!", routeNo);
}
}
conn.Close();
Console.WriteLine("插入{0}条、更新{1}条线路",count, count0);
}
}

结果如下

将Excel数据导入数据库