c 批量导入mysql数据库_C#.NET中如何批量插入大量数据到数据库中
在WEB項目開發過程中有時會碰到批量插入數據到數或者是將EXCEL文件據入到數據庫中.為了方便實現可以先將EXCEL導入到GRIDVIEW中然后一次批量插入.實現代碼如下:
前臺代碼
后臺代碼:
//首先在命名空間中加入以下兩行
using System.Data.SqlClient;
using System.Data.OleDb;
protected void btn2_Click(object sender, EventArgs e)
{
string filepath = FileUpload1.PostedFile.FileName;
ReadExcel(filepath, dgBom);
}
public void ReadExcel(string sExcelFile, GridView dgBom)
{
DataTable ExcelTable;
DataSet ds = new DataSet();
//Excel的連接
OleDbConnection objConn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + sExcelFile + ";" + "Extended Properties=Excel 8.0;");
objConn.Open();
DataTable schemaTable = objConn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
string tableName = schemaTable.Rows[0][2].ToString().Trim();//獲取 Excel 的表名,默認值是sheet1
string strSql = "select * from [" + tableName + "]";
OleDbCommand objCmd = new OleDbCommand(strSql, objConn);
OleDbDataAdapter myData = new OleDbDataAdapter(strSql, objConn);
myData.Fill(ds, tableName);//填充數據
dgBom.DataSource =ds;
dgBom.DataBind();
objConn.Close();
ExcelTable = ds.Tables[tableName];
int iColums = ExcelTable.Columns.Count;//列數
int iRows = ExcelTable.Rows.Count;//行數
//定義二維數組存儲 Excel 表中讀取的數據
string[,] storedata = new string[iRows, iColums];
for(int i=0;i
for (int j = 0; j < ExcelTable.Columns.Count; j++)
{
//將Excel表中的數據存儲到數組
storedata[i, j] = ExcelTable.Rows[i][j].ToString();
}
int excelBom = 0;//記錄表中有用信息的行數,有用信息是指除去表的標題和表的欄目,本例中表的用用信息是從第三行開始
//確定有用的行數
for (int k = 2; k < ExcelTable.Rows.Count; k++)
if (storedata[k, 1] != "")
excelBom++;
if (excelBom == 0)
{
Response.Write("");
}
else
{
//LoadDataToDataBase(storedata,excelBom)//該函數主要負責將 storedata 中有用的數據寫入到數據庫中,在此不是問題的關鍵省略
}
}
protected void btninsert_Click(object sender, EventArgs e)
{
foreach (GridViewRow gv in dgBom.Rows)
{
//我的連接字符串是寫在WEB.CONFIG中的.
string con = System.Configuration.ConfigurationManager.AppSettings["ConnectionString1"].ToString();
SqlConnection conn = new SqlConnection(con);
SqlCommand cmd = conn.CreateCommand();
cmd.CommandType = CommandType.Text;
cmd.CommandText = "insert into student (studentnumber,studentname) values(@studentnumber,@studentname)";
cmd.Parameters.Add("@studentnumber", SqlDbType.NVarChar, 20);
cmd.Parameters.Add("@studentname", SqlDbType.NVarChar, 10);
cmd.Parameters["@studentname"].Value = ((TextBox)gv.FindControl("studentname")).Text;
cmd.Parameters["@studentnumber"].Value = ((TextBox)gv.FindControl("studentnumber")).Text;
try
{
conn.Open();
cmd.ExecuteNonQuery();
conn.Close();
}
finally
{
if (conn != null)
conn.Dispose();
}
}
}
以上內容就是本文的全部敘述,希望對大家學習C#.NET中如何批量插入大量數據到數據庫中有所幫助。
總結
以上是生活随笔為你收集整理的c 批量导入mysql数据库_C#.NET中如何批量插入大量数据到数据库中的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 电脑播放视频没有声音是怎么回事啊(电脑播
- 下一篇: mysql十大报错_MySQL十大报错函