日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决

發(fā)布時間:2023/12/18 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

C#使用oledb連接excel執(zhí)行Insert Into語句出現(xiàn)“操作必須使用一個可更新的查詢”的解決辦法

我發(fā)生錯誤時的環(huán)境:Windows 7,Framework 4、0,Microsoft Office 2007,VS2010,c# WinForm; 部分代碼: [csharp]?view plaincopy
  • string?strConn?=?"Provider=Microsoft.Ace.OleDb.12.0;Persist?Security?Info=False;"?+?"data?source="?+?@excelPath?+?";Extended?Properties='Excel?12.0;?HDR=yes;?IMEX=2'";??
  • OleDbConnection?conn?=?new?OleDbConnection();??
  • conn.ConnectionString?=?strConn;??
  • try??
  • {??
  • ????OleDbCommand?cmd?=?null;??
  • ????try??
  • ????{??
  • ????????cmd?=?new?OleDbCommand("Insert?Into?[Sheet1$]?Values('abc',?'bac',?'0',?'123456',?'test','測試','aa')",?conn);//(A,B,C,D,E,F,G)???
  • ????????cmd.ExecuteNonQuery();??
  • ????}??
  • ????catch?(System.Exception?ex)??
  • ????{??
  • ????????textBox1.Text?+=?("插入數(shù)據(jù)失敗:"?+?ex.Message);??
  • ????????textBox1.Text?+=?("\r\n");??
  • ????}??
  • 遇到此錯誤的時候第一想到的就是沒有權限,但使用管理員身份運行依然是相同的錯誤! 又通過以下代碼添加權限,還是一樣的錯誤: [csharp]?view plaincopy
  • FileInfo?fi?=?new?FileInfo(excelPath);??
  • System.Security.AccessControl.FileSecurity?fileSecurity?=?fi.GetAccessControl();??
  • fileSecurity.AddAccessRule(new?FileSystemAccessRule("Everyone",?FileSystemRights.FullControl,?AccessControlType.Allow));??
  • fileSecurity.AddAccessRule(new?FileSystemAccessRule("Users",?FileSystemRights.FullControl,?AccessControlType.Allow));??
  • fi.SetAccessControl(fileSecurity);??
  • ??
  • DirectoryInfo?di?=?new?DirectoryInfo(Path.GetDirectoryName(excelPath));??
  • System.Security.AccessControl.DirectorySecurity?dirSecurity?=?di.GetAccessControl();??
  • dirSecurity.AddAccessRule(new?FileSystemAccessRule("Everyone",?FileSystemRights.FullControl,?AccessControlType.Allow));??
  • dirSecurity.AddAccessRule(new?FileSystemAccessRule("Users",?FileSystemRights.FullControl,?AccessControlType.Allow));??
  • di.SetAccessControl(dirSecurity);??
  • 知識補習,這里的連接字符串多了:Extended Properties='Excel 12.0; HDR=yes; IMEX=2'

    參數(shù)HDR的值:

    HDR=Yes,這代表第一行是標題,不做為數(shù)據(jù)使用 ,如果用HDR=NO,則表示第一行不是標題,做為數(shù)據(jù)來使用。系統(tǒng)默認的是YES
    參數(shù)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 參數(shù)了,因為不同的模式代表著不同的讀寫行為:
      當 IMEX=0 時為“匯出模式”,這個模式開啟的 Excel 檔案只能用來做“寫入”用途。
      當 IMEX=1 時為“匯入模式”,這個模式開啟的 Excel 檔案只能用來做“讀取”用途。
      當 IMEX=2 時為“連結(jié)模式”,這個模式開啟的 Excel 檔案可同時支援“讀取”與“寫入”用途。
    意義如下:
    0 ---輸出模式;
    1---輸入模式;
    2----鏈接模式(完全更新能力) 按照以上描述,上面的連接字符串應該是可以讀取,插件記錄的
    但是事實并非如此,當執(zhí)行Insert Into語句時卻出現(xiàn)異常:“操作必須使用一個可更新的查詢”!
    注意是c# WinForm程序,不是Web應用程序;如果是Web應用程序,那需要添加IIS_IUSRS或IIS_Service用戶的目錄訪問權限;
    還是去搜索看看別人是怎么解決的吧,但是看遍了別人解決問題的方法,到我這里就是測試不通過! 猜測還是IMEX值的問題,改為1不行,那就改為0,尼馬,奇跡出現(xiàn)了!? 接著又測試將IMEX設置為4或10,結(jié)果都沒問題,唯獨1和2不行,真是坑爹的節(jié)奏啊

    總結(jié)

    以上是生活随笔為你收集整理的连接excel执行Insert Into语句出现“操作必须使用一个可更新的查询”的解决的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。