日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

c 批量导入mysql数据库_C#.NET中如何批量插入大量数据到数据库中

發(fā)布時間:2025/4/5 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c 批量导入mysql数据库_C#.NET中如何批量插入大量数据到数据库中 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在WEB項目開發(fā)過程中有時會碰到批量插入數(shù)據(jù)到數(shù)或者是將EXCEL文件據(jù)入到數(shù)據(jù)庫中.為了方便實現(xiàn)可以先將EXCEL導(dǎo)入到GRIDVIEW中然后一次批量插入.實現(xiàn)代碼如下:

前臺代碼

后臺代碼:

//首先在命名空間中加入以下兩行

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 的表名,默認(rèn)值是sheet1

string strSql = "select * from [" + tableName + "]";

OleDbCommand objCmd = new OleDbCommand(strSql, objConn);

OleDbDataAdapter myData = new OleDbDataAdapter(strSql, objConn);

myData.Fill(ds, tableName);//填充數(shù)據(jù)

dgBom.DataSource =ds;

dgBom.DataBind();

objConn.Close();

ExcelTable = ds.Tables[tableName];

int iColums = ExcelTable.Columns.Count;//列數(shù)

int iRows = ExcelTable.Rows.Count;//行數(shù)

//定義二維數(shù)組存儲 Excel 表中讀取的數(shù)據(jù)

string[,] storedata = new string[iRows, iColums];

for(int i=0;i

for (int j = 0; j < ExcelTable.Columns.Count; j++)

{

//將Excel表中的數(shù)據(jù)存儲到數(shù)組

storedata[i, j] = ExcelTable.Rows[i][j].ToString();

}

int excelBom = 0;//記錄表中有用信息的行數(shù),有用信息是指除去表的標(biāo)題和表的欄目,本例中表的用用信息是從第三行開始

//確定有用的行數(shù)

for (int k = 2; k < ExcelTable.Rows.Count; k++)

if (storedata[k, 1] != "")

excelBom++;

if (excelBom == 0)

{

Response.Write("");

}

else

{

//LoadDataToDataBase(storedata,excelBom)//該函數(shù)主要負(fù)責(zé)將 storedata 中有用的數(shù)據(jù)寫入到數(shù)據(jù)庫中,在此不是問題的關(guān)鍵省略

}

}

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();

}

}

}

以上內(nèi)容就是本文的全部敘述,希望對大家學(xué)習(xí)C#.NET中如何批量插入大量數(shù)據(jù)到數(shù)據(jù)庫中有所幫助。

總結(jié)

以上是生活随笔為你收集整理的c 批量导入mysql数据库_C#.NET中如何批量插入大量数据到数据库中的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。