1. 程式人生 > >提示未在本地計算機上註冊 Microsoft.ACE.OLEDB.12.0 提供程式

提示未在本地計算機上註冊 Microsoft.ACE.OLEDB.12.0 提供程式

連線access資料庫出現如下錯誤提示:

此種錯誤有兩種原因:

【1】軟體編譯版本64位與32位的問題

解決方法:

此時可能是因為在VS中編譯選擇的處理器為“Any Cpu”,可以將其改為“x86”,然後重新編譯打包。

 

【2】office版本問題,對於office2007的連線字串與其它版本的連線字串是不同的,因為使用的資料庫引擎不同。

【3】微軟從XP開始在系統中已經集成了JET引擎,不需要安裝Office,因此將解決方案平臺選擇為X86,然後將連線字串改成"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Datas.mdb;Jet OLEDB:Database Password=scut_robot

",無論對於哪個版本的access都可以使用。在使用OLEDB時候也同樣改成JET引擎。

  1. C#儲存excel檔案時提示檔案格式與副檔名不匹配

如果儲存生成的excel檔案提示如下錯誤,

可以通過設定儲存excel格式來解決。

【例】

public static string xlsFilePath = @"D:\";//excel檔案存放路徑

 

        /// <summary>

        /// 匯出資料到excel檔案

        /// </summary>

        /// <param name="dt">要匯出的資料集</param>

        /// <returns>生成的檔名</returns>

        static public string ExporeToExcel(DataTable dt)

        {

            MSExcel.Application excelApp = null;

            MSExcel.Workbooks wbks = null;

            MSExcel._Workbook wbk = null;

            try

            {

                string strDir = Directory.GetCurrentDirectory();

                excelApp = new MSExcel.Application();

                excelApp.Visible = false;//是開啟不可見

                wbks = excelApp.Workbooks;

                wbk = wbks.Add(true);

 

                String version = excelApp.Version;//獲取你使用的excel 的版本號

                int FormatNum;//儲存excel檔案的格式

                if (Convert.ToDouble(version) < 12)//You use Excel 97-2003

                {

                    FormatNum = -4143;

                }

                else//you use excel 2007 or later

                {

                    FormatNum = 56;

                }

               

                object Nothing = Missing.Value;

                MSExcel._Worksheet whs;

                whs = (MSExcel._Worksheet)wbk.Sheets[1];//獲取第一張工作表

                whs.Activate();

 

                //寫入標題行

                int rowIndex=1;

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

                {

                    whs.Cells[rowIndex, col+1] = dt.Columns[col].Caption.ToString();

                }

                rowIndex++;

                //寫入資料內容

                foreach (DataRow row in dt.Rows)

                {

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

                    {

                        whs.Cells[rowIndex, colIndex + 1] = row[colIndex].ToString();

                    }

                    rowIndex++;

                }

 

                excelApp.DisplayAlerts = false;

                //儲存excel檔案

               

                string newFileName = xlsFilePath + "匯出的excel檔案" + DateTime.Now.ToString("yyyyMMddhhmmss") + ".xls";

                wbk.SaveAs(newFileName, FormatNum);//儲存時候設定儲存格式

                //關閉檔案

                wbk.Close(false, Nothing, Nothing);

                return newFileName;

              

            }

            catch (Exception e)

            {

                throw e;

            }

            finally

            {

                //wbks.Close();//關閉工作簿

                excelApp.Quit();//關閉excel應用程式

                System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);//釋放excel程序

                excelApp = null;

            }

          

        }