Вставка данных листа Excel в хранимую процедуру на сервере sql с использованием asp.net
Разработка Asp.Net для этого будет извлекать данные из таблицы Excel, а затем вставлять их в хранимую процедуру, во время моего поиска я знал, что это невозможно, и я могу скопировать данные из таблицы Excel в временную таблицу, а затем из временной таблицы в хранимую процедуру здесь. это код, который я использую для вставки данных в обычную таблицу, пожалуйста, помогите
public partial class WebForm1 : System.Web.UI.Page
{
OleDbConnection Econ;
SqlConnection con;
string constr, Query, sqlconn;
protected void Page_Load(object sender, EventArgs e)
{
}
private void ExcelConn(string FilePath)
{
constr = string.Format(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=""Excel 12.0 Xml;HDR=YES;""", FilePath);
Econ = new OleDbConnection(constr);
}
private void connection()
{
sqlconn = ConfigurationManager.ConnectionStrings["InvoiceProjectConnectionString"].ConnectionString;
con = new SqlConnection(sqlconn);
}
protected void Button1_Click(object sender, EventArgs e)
{
string CurrentFilePath = Path.GetFullPath(FileUpload1.PostedFile.FileName);
InsertExcelRecords(CurrentFilePath);
}
private void InsertExcelRecords(string FilePath)
{
ExcelConn(FilePath);
Query = string.Format("Select [CODE],[Brand],[SubBrand],[SubBrand2],[Category],[Category2] FROM [{0}]", "Sheet1$");
OleDbCommand Ecom = new OleDbCommand(Query, Econ);
Econ.Open();
DataSet ds = new DataSet();
OleDbDataAdapter oda = new OleDbDataAdapter(Query, Econ);
Econ.Close();
oda.Fill(ds);
DataTable Exceldt = ds.Tables[0];
connection();
//creating object of SqlBulkCopy
SqlBulkCopy objbulk = new SqlBulkCopy(con);
//assigning Destination table name
objbulk.DestinationTableName = "tblTest";
//Mapping Table column
objbulk.ColumnMappings.Add("CODE", "Code");
objbulk.ColumnMappings.Add("Brand", "Brand");
objbulk.ColumnMappings.Add("SubBrand", "SubBrandOne");
objbulk.ColumnMappings.Add("SubBrand2", "SubBrandTwo");
objbulk.ColumnMappings.Add("Category", "Category");
objbulk.ColumnMappings.Add("Category2", "CategoryTwo");
//inserting Datatable Records to DataBase
con.Open();
objbulk.WriteToServer(Exceldt);
con.Close();
}
}
1 ответ
Решение
Ваш код в порядке, но не завершен...
protected void Button1_Click(object sender, EventArgs e)
{
string CurrentFilePath = Path.GetFullPath(FileUpload1.PostedFile.FileName);
//step 1...
InsertExcelRecords(CurrentFilePath);
//step 2: execute your procedure on sql-server that read your temp-table "tblTest" and insert on your table
PopulateTable();
}
protected void PopulateTable(){
//Your code for execute your procedure...
}
пример выполнения процедуры на sql-сервере: как выполнить хранимую процедуру в программе на C#