C# 使用oledb連線excel執行Insert Into語句出現“操作必須使用一個可更新的查詢”的解決辦法
阿新 • • 發佈:2021-10-28
知識補習,這裡的連線字串多了:Extended Properties='Excel 12.0; HDR=yes; IMEX=2'
引數Excel 8.0對於Excel 97以上到2003版本都用Excel 8.0,2007或2010的都用Extended Properties=Excel 12.0 IMEX ( IMport EXport mode )設定
IMEX 有三種模式:
0 is Export mode
1 is Import mode
2 is Linked mode (full update capabilities)
我這裡特別要說明的就是 IMEX 引數了,因為不同的模式代表著不同的讀寫行為:
當 IMEX=0 時為“匯出模式”,這個模式開啟的 Excel 檔案只能用來做“寫入”用途。
當 IMEX=1 時為“匯入模式”,這個模式開啟的 Excel 檔案只能用來做“讀取”用途。
當 IMEX=2 時為“連結模式”,這個模式開啟的 Excel 檔案可同時支援“讀取”與“寫入”用途。
意義如下:
0 ---輸出模式;
1---輸入模式;
2----連結模式(完全更新能力) 按照以上描述,上面的連線字串應該是可以讀取,外掛記錄的 但是事實並非如此,當執行Insert Into語句時卻出現異常:“操作必須使用一個可更新的查詢”!
引數HDR的值:
HDR=Yes,這代表第一行是標題,不做為資料使用 ,如果用HDR=NO,則表示第一行不是標題,做為資料來使用。系統預設的是YES引數Excel 8.0對於Excel 97以上到2003版本都用Excel 8.0,2007或2010的都用Extended Properties=Excel 12.0 IMEX ( IMport EXport mode )設定
IMEX 有三種模式:
0 is Export mode
1 is Import mode
2 is Linked mode (full update capabilities)
我這裡特別要說明的就是 IMEX 引數了,因為不同的模式代表著不同的讀寫行為:
當 IMEX=0 時為“匯出模式”,這個模式開啟的 Excel 檔案只能用來做“寫入”用途。
當 IMEX=1 時為“匯入模式”,這個模式開啟的 Excel 檔案只能用來做“讀取”用途。
當 IMEX=2 時為“連結模式”,這個模式開啟的 Excel 檔案可同時支援“讀取”與“寫入”用途。
意義如下:
0 ---輸出模式;
1---輸入模式;
2----連結模式(完全更新能力) 按照以上描述,上面的連線字串應該是可以讀取,外掛記錄的 但是事實並非如此,當執行Insert Into語句時卻出現異常:“操作必須使用一個可更新的查詢”!
解決方法: 把IMEX=2或者=1的值改為0 就可以正常寫入
String sConnectionString = string.Empty; if (!fileName.Contains(".xlsx")) sConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + "Extended Properties='Excel 8.0;HDR = Yes;IMEX = 0'"; else sConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source = " + fileName + "; Extended Properties = 'Excel 12.0; HDR = YES;IMEX = 0'";