ASP.NETÖÐ Execlµ¼³öµÄÁùÖÖ·½·¨ÊµÀý

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡/// <summary>

¡¡¡¡/// µ¼³öExcel

¡¡¡¡/// </summary>

¡¡¡¡/// <param name="page"></param>

¡¡¡¡/// <param name="dt"></param>

¡¡¡¡//·½·¨Ò»£º

¡¡¡¡public void ImportExcel(Page page, DataTable dt)

¡¡¡¡{

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string filename = Guid.NewGuid().ToString() + ".xls";

¡¡¡¡string webFilePath = page.Server.MapPath("/" + filename);

¡¡¡¡CreateExcelFile(webFilePath, dt);

¡¡¡¡using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate))

¡¡¡¡{

¡¡¡¡//ÈÃÓû§ÊäÈëÏÂÔØµÄ±¾µØµØÖ·

¡¡¡¡page.Response.Clear();

¡¡¡¡page.Response.Buffer = true;

¡¡¡¡page.Response.Charset = "GB2312";

¡¡¡¡//page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls");

¡¡¡¡page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename);

¡¡¡¡page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");

¡¡¡¡page.Response.ContentType = "application/ms-excel";

¡¡¡¡// ¶ÁÈ¡excelÊý¾Ýµ½ÄÚ´æ

¡¡¡¡byte[] buffer = new byte[fs.Length - 1];

¡¡¡¡fs.Read(buffer, 0, (int)fs.Length - 1);

¡¡¡¡// дµ½aspxÒ³Ãæ

¡¡¡¡page.Response.BinaryWrite(buffer);

¡¡¡¡page.Response.Flush();

¡¡¡¡//this.ApplicationInstance.CompleteRequest(); //Í£Ö¹Ò³µÄÖ´ÐÐ

¡¡¡¡fs.Close();

¡¡¡¡fs.Dispose();

¡¡¡¡//ɾ³ýÁÙʱÎļþ

¡¡¡¡File.Delete(webFilePath);

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡}

¡¡¡¡·½·¨¶þ£º

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡public void ImportExcel(Page page, DataSet ds)

¡¡¡¡{

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string filename = Guid.NewGuid().ToString() + ".xls";

¡¡¡¡string webFilePath = page.Server.MapPath("/" + filename);

¡¡¡¡CreateExcelFile(webFilePath, ds);

¡¡¡¡using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate))

¡¡¡¡{

¡¡¡¡//ÈÃÓû§ÊäÈëÏÂÔØµÄ±¾µØµØÖ·

¡¡¡¡page.Response.Clear();

¡¡¡¡page.Response.Buffer = true;

¡¡¡¡page.Response.Charset = "GB2312";

¡¡¡¡//page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls");

¡¡¡¡page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename);

¡¡¡¡page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");

¡¡¡¡page.Response.ContentType = "application/ms-excel";

¡¡¡¡// ¶ÁÈ¡excelÊý¾Ýµ½ÄÚ´æ

¡¡¡¡byte[] buffer = new byte[fs.Length - 1];

¡¡¡¡fs.Read(buffer, 0, (int)fs.Length - 1);

¡¡¡¡// дµ½aspxÒ³Ãæ

¡¡¡¡page.Response.BinaryWrite(buffer);

¡¡¡¡page.Response.Flush();

¡¡¡¡//this.ApplicationInstance.CompleteRequest(); //Í£Ö¹Ò³µÄÖ´ÐÐ

¡¡¡¡fs.Close();

¡¡¡¡fs.Dispose();

¡¡¡¡//ɾ³ýÁÙʱÎļþ

¡¡¡¡File.Delete(webFilePath);

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡}

¡¡¡¡·½·¨Èý£º

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡public void ImportExcel(Page page, DataTable dt1, DataTable dt2, string conditions)

¡¡¡¡{

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string filename = Guid.NewGuid().ToString() + ".xls";

¡¡¡¡string webFilePath = page.Server.MapPath("/" + filename);

¡¡¡¡CreateExcelFile(webFilePath, dt1, dt2, conditions);

¡¡¡¡using (FileStream fs = new FileStream(webFilePath, FileMode.OpenOrCreate))

¡¡¡¡{

¡¡¡¡//ÈÃÓû§ÊäÈëÏÂÔØµÄ±¾µØµØÖ·

¡¡¡¡page.Response.Clear();

¡¡¡¡page.Response.Buffer = true;

¡¡¡¡page.Response.Charset = "GB2312";

¡¡¡¡//page.Response.AppendHeader("Content-Disposition", "attachment;filename=MonitorResult.xls");

¡¡¡¡page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename);

¡¡¡¡page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");

¡¡¡¡page.Response.ContentType = "application/ms-excel";

¡¡¡¡// ¶ÁÈ¡excelÊý¾Ýµ½ÄÚ´æ

¡¡¡¡byte[] buffer = new byte[fs.Length - 1];

¡¡¡¡fs.Read(buffer, 0, (int)fs.Length - 1);

¡¡¡¡// дµ½aspxÒ³Ãæ

¡¡¡¡page.Response.BinaryWrite(buffer);

¡¡¡¡page.Response.Flush();

¡¡¡¡//this.ApplicationInstance.CompleteRequest(); //Í£Ö¹Ò³µÄÖ´ÐÐ

¡¡¡¡fs.Close();

¡¡¡¡fs.Dispose();

¡¡¡¡//ɾ³ýÁÙʱÎļþ

¡¡¡¡File.Delete(webFilePath);

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡}

¡¡¡¡·½·¨ËÄ£º

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡private void CreateExcelFile(string filePath, DataTable dt)

¡¡¡¡{

¡¡¡¡if (File.Exists(filePath))

¡¡¡¡{

¡¡¡¡File.Delete(filePath);

¡¡¡¡}

¡¡¡¡OleDbConnection oleDbConn = new OleDbConnection();

¡¡¡¡OleDbCommand oleDbCmd = new OleDbCommand();

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string sSql = "";

¡¡¡¡oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;""";

¡¡¡¡oleDbConn.Open();

¡¡¡¡oleDbCmd.CommandType = CommandType.Text;

¡¡¡¡oleDbCmd.Connection = oleDbConn;

¡¡¡¡//дÁÐÃû

¡¡¡¡sSql = "CREATE TABLE sheet1(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text,";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text)";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡for (int j = 0; j < dt.Rows.Count; j++)

¡¡¡¡{

¡¡¡¡sSql = "INSERT INTO sheet1 VALUES(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ",";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "',";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ")";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "')";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (System.Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡finally

¡¡¡¡{

¡¡¡¡//¶Ï¿ªÁ¬½Ó

¡¡¡¡oleDbCmd.Dispose();

¡¡¡¡oleDbConn.Close();

¡¡¡¡oleDbConn.Dispose();

¡¡¡¡}

¡¡¡¡}

¡¡¡¡·½·¨Î壺

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡private void CreateExcelFile(string filePath, DataSet ds)

¡¡¡¡{

¡¡¡¡if (File.Exists(filePath))

¡¡¡¡{

¡¡¡¡File.Delete(filePath);

¡¡¡¡}

¡¡¡¡OleDbConnection oleDbConn = new OleDbConnection();

¡¡¡¡OleDbCommand oleDbCmd = new OleDbCommand();

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string sSql = "";

¡¡¡¡oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;""";

¡¡¡¡oleDbConn.Open();

¡¡¡¡oleDbCmd.CommandType = CommandType.Text;

¡¡¡¡oleDbCmd.Connection = oleDbConn;

¡¡¡¡//дÁÐÃû

¡¡¡¡for(int k=0;k<ds.Tables.Count;k++)

¡¡¡¡{

¡¡¡¡DataTable dt = ds.Tables[k];

¡¡¡¡sSql = "CREATE TABLE sheet" + (k + 1).ToString() + "(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String" || dt.Columns[i].DataType.Name=="Guid")

¡¡¡¡{

¡¡¡¡sSql += "["+dt.Columns[i].ColumnName + "] Text,";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text)";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery(); for (int j = 0; j < dt.Rows.Count; j++)

¡¡¡¡{

¡¡¡¡sSql = "INSERT INTO sheet" + (k + 1).ToString() + " VALUES(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ",";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString().Replace("'", "''") + "',";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ")";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString().Replace("'","''") + "')";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (System.Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡finally

¡¡¡¡{

¡¡¡¡//¶Ï¿ªÁ¬½Ó

¡¡¡¡oleDbCmd.Dispose();

¡¡¡¡oleDbConn.Close();

¡¡¡¡oleDbConn.Dispose();

¡¡¡¡}

¡¡¡¡}

¡¡¡¡·½·¨Áù£º

¡¡¡¡

¸´ÖÆ´úÂë ´úÂëÈçÏÂ:

¡¡¡¡private void CreateExcelFile(string filePath, DataTable dt1,DataTable dt2,string conditions)

¡¡¡¡{

¡¡¡¡if (File.Exists(filePath))

¡¡¡¡{

¡¡¡¡File.Delete(filePath);

¡¡¡¡}

¡¡¡¡OleDbConnection oleDbConn = new OleDbConnection();

¡¡¡¡OleDbCommand oleDbCmd = new OleDbCommand();

¡¡¡¡try

¡¡¡¡{

¡¡¡¡string sSql = "";

¡¡¡¡oleDbConn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + filePath + @";Extended ProPerties=""Excel 8.0;HDR=Yes;""";

¡¡¡¡oleDbConn.Open();

¡¡¡¡oleDbCmd.CommandType = CommandType.Text;

¡¡¡¡oleDbCmd.Connection = oleDbConn;

¡¡¡¡//дÁÐÃû

¡¡¡¡sSql = "CREATE TABLE sheet1(";

¡¡¡¡DataTable dt = dt1.Copy();

¡¡¡¡dt.Columns.Remove("MGUID");

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text,";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text)";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡DataView dv = new DataView();

¡¡¡¡dv.Table = dt;

¡¡¡¡DataView dv1 = new DataView();

¡¡¡¡dv1.Table = dt1;

¡¡¡¡if (conditions != "")

¡¡¡¡{

¡¡¡¡dv.RowFilter = conditions;

¡¡¡¡dv1.RowFilter = conditions;

¡¡¡¡}

¡¡¡¡dt = dv.ToTable();

¡¡¡¡dt1 = dv1.ToTable();

¡¡¡¡string MGUIDs = "";

¡¡¡¡for (int j = 0; j < dt.Rows.Count; j++)

¡¡¡¡{

¡¡¡¡MGUIDs += ",'" + dt1.Rows[j]["MGUID"].ToString() + "'";

¡¡¡¡sSql = "INSERT INTO sheet1 VALUES(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ",";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "',";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ")";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "')";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡}

¡¡¡¡if (dt2 != null)

¡¡¡¡{

¡¡¡¡sSql = "CREATE TABLE sheet21(";

¡¡¡¡dt = dt2.Copy();

¡¡¡¡dt.Columns.Remove("MGUID");

¡¡¡¡dt.Columns.Remove("DGUID");

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text,";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Datetime,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal,";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "String")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Text)";

¡¡¡¡}

¡¡¡¡else if (dt.Columns[i].DataType.Name == "DateTime")

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] DateTime)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "[" + dt.Columns[i].ColumnName + "] Decimal)";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡dv = new DataView();

¡¡¡¡dv.Table = dt2;

¡¡¡¡if (MGUIDs != "")

¡¡¡¡{

¡¡¡¡dv.RowFilter = "MGUID in(" + MGUIDs.Substring(1) + ")";

¡¡¡¡}

¡¡¡¡dt = dv.ToTable();

¡¡¡¡for (int j = 0; j < dt.Rows.Count; j++)

¡¡¡¡{

¡¡¡¡sSql = "INSERT INTO sheet1 VALUES(";

¡¡¡¡for (int i = 0; i < dt.Columns.Count; i++)

¡¡¡¡{

¡¡¡¡if (i < dt.Columns.Count - 1)

¡¡¡¡{

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL,";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ",";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "',";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡else

¡¡¡¡if (DBNull.Value.Equals(dt.Rows[j][i]))

¡¡¡¡{

¡¡¡¡sSql += "NULL)";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡if (dt.Columns[i].DataType.Name == "Decimal")

¡¡¡¡{

¡¡¡¡sSql += dt.Rows[j][i].ToString() + ")";

¡¡¡¡}

¡¡¡¡else

¡¡¡¡{

¡¡¡¡sSql += "'" + dt.Rows[j][i].ToString() + "')";

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡oleDbCmd.CommandText = sSql;

¡¡¡¡oleDbCmd.ExecuteNonQuery();

¡¡¡¡}

¡¡¡¡}

¡¡¡¡}

¡¡¡¡catch (System.Exception ex)

¡¡¡¡{

¡¡¡¡throw ex;

¡¡¡¡}

¡¡¡¡finally

¡¡¡¡{

¡¡¡¡//¶Ï¿ªÁ¬½Ó

¡¡¡¡oleDbCmd.Dispose();

¡¡¡¡oleDbConn.Close();

¡¡¡¡oleDbConn.Dispose();

¡¡¡¡}

¡¡¡¡}