1.功能分析
通過Microsoft.Jet.OLEDB.4.0方式可實現使用ADO.NET訪問Excel的目的,如以下示例代碼為連接Excel數據的字符串:
復制代碼 代碼如下:
string strOdbcCon = @"Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False;Data Source=D:\2010年圖書銷售情況.xls;Extended Properties=Excel 8.0";
2.實施方法 程序開發步驟:
(1)新建一個網站,命名為25,其主頁默認為Default.aspx。
(2)Default.aspx頁面中添加一個Table表格,用來布局頁面,然後在該Table表格中添加一個iframe框架、兩個Button控件和一個GridView控件,其中,iframe框架用來顯示原始Excel數據表中的數據;Button控件分別用來將指定Excel中的數據表導入到SQL Server數據庫中和將導入SQL Server數據庫中的Excel數據綁定到GridView控件上;GridView控件用來顯示導入SQL Server數據庫中的Excel數據。
(3)程序主要代碼如下。
Default.aspx頁面中,首先自定義一個LoadData方法,該方法為無返回值類型方法,主要用來將Excel數據表中的數據導入到SQL Server數據庫中。LoadData方法實現代碼如下:
復制代碼 代碼如下:
public void LoadData(string StyleSheet)
{
string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source =" + Server.MapPath
("usersdb.xls") + ";Extended Properties=Excel 8.0";
OleDbConnection myConn = new OleDbConnection(strCon);
myConn.Open(); //打開數據鏈接,得到一個數據集
DataSet myDataSet = new DataSet(); //創建DataSet對象
string StrSql = "select * from [" + StyleSheet + "$]";
OleDbDataAdapter myCommand = new OleDbDataAdapter(StrSql, myConn);
myCommand.Fill(myDataSet, "[" + StyleSheet + "$]");
myCommand.Dispose();
DataTable DT = myDataSet.Tables["[" + StyleSheet + "$]"];
myConn.Close();
myCommand.Dispose();
string strConn = "Data Source=(local);DataBase=Usersdb;Uid=sa;Pwd=";
SqlConnection conn = new SqlConnection(strConn);
conn.Open();
for (int j = 0; j < DT.Rows.Count; j++)
{
string UserID = DT.Rows[j][0].ToString();
string EmailAddress = DT.Rows[j][1].ToString();
string FirstName = DT.Rows[j][2].ToString();
string LastName = DT.Rows[j][3].ToString();
string Address1 = DT.Rows[j][4].ToString();
string Address2 = DT.Rows[j][5].ToString();
string City = DT.Rows[j][6].ToString();
string strSql = "insert into Usersdb(EmailAddress,FirstName,
LastName,Address1,Address2,City) ";
strSql = strSql + "values('" + EmailAddress + "','" + FirstName + "',
'" + LastName + "','" + Address1 + "','" + Address2 + "','" + City + "')";
SqlCommand comm = new SqlCommand(strSql, conn);
comm.ExecuteNonQuery();
if (j == DT.Rows.Count - 1)
{
Label1.Visible = true;
}
else
{
Label1.Visible = false;
}
}
conn.Close();
}
單擊【Excel數據寫入數據庫中】按鈕,定義一個string類型的變量,用來為LoadData傳入參數,然後調用LoadData自定義方法將指定的Excel中的數據表導入到SQL Server數據庫中。【Excel數據寫入數據庫中】按鈕的Click事件代碼如下:
復制代碼 代碼如下:
protected void Button1_Click(object sender, EventArgs e)
{
string StyleSheet = "Sheet1";
LoadData(StyleSheet);
}
單擊【顯示導入SQL的Excel數據】按鈕,將導入SQL Server數據庫中的Excel數據綁定到GridView控件上,顯示在網頁中。【顯示導入SQL的Excel數據】按鈕的Click事件代碼如下:
復制代碼 代碼如下:
protected void Button2_Click(object sender, EventArgs e)
{
string strConn = "Data Source=(local);DataBase=Usersdb;Uid=sa;Pwd=";
string sqlstr="select * from Usersdb";
SqlConnection conn = new SqlConnection(strConn);
SqlDataAdapter myda = new SqlDataAdapter(sqlstr,conn);
DataSet ds = new DataSet();
conn.Open();
myda.Fill(ds, "Usersdb");
GridView1.DataSource = ds;
GridView1.DataBind();
conn.Close();
}
說明:程序中進行與Excel和SQL Server數據庫相關的操作時,首先需要分別添加System.Data.OleDb和System.Data.SqlClient命名空間。
3.補充說明
除了可以將Excel中數據導入到SQL Server數據庫外,還可以將其轉換為.txt文本文件格式,或者導入到Access或Oracle等數據庫中。