连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决
生活随笔
收集整理的這篇文章主要介紹了
连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
C#使用oledb連接excel執行Insert Into語句出現“操作必須使用一個可更新的查詢”的解決辦法
我發生錯誤時的環境:Windows 7,Framework 4、0,Microsoft Office 2007,VS2010,c# WinForm; 部分代碼: [csharp]?view plaincopy參數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語句時卻出現異常:“操作必須使用一個可更新的查詢”!
注意是c# WinForm程序,不是Web應用程序;如果是Web應用程序,那需要添加IIS_IUSRS或IIS_Service用戶的目錄訪問權限;
還是去搜索看看別人是怎么解決的吧,但是看遍了別人解決問題的方法,到我這里就是測試不通過! 猜測還是IMEX值的問題,改為1不行,那就改為0,尼馬,奇跡出現了!? 接著又測試將IMEX設置為4或10,結果都沒問題,唯獨1和2不行,真是坑爹的節奏啊
總結
以上是生活随笔為你收集整理的连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 广州科目三考试 不得不看的十条提醒(图)
- 下一篇: 操作excel的一些方法