ホームページ バックエンド開発 C#.Net チュートリアル C# が oledb を使用して Excel に接続し、Insert Into ステートメントを実行する「更新可能なクエリを使用する必要がある」という問題を解決するサンプル コードです。

C# が oledb を使用して Excel に接続し、Insert Into ステートメントを実行する「更新可能なクエリを使用する必要がある」という問題を解決するサンプル コードです。

Mar 13, 2017 pm 05:46 PM

エラーが発生した時の環境: Windows 7、Framework 4、0、Microsoft Office 2007、VS2010、c# WinForm; コードの一部:

                    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 += ("插入数据失败:" + ex.Message);
                            textBox1.Text += ("\r\n");
                        }
ログイン後にコピー


エラー 最初に思い浮かぶのは、権限がないにもかかわらず、管理者として実行しても同じエラーが発生するということです。

次のコードでアクセス許可を追加しましたが、同じエラーが発生します:

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=yes; パラメータ 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モード)設定
IMEXには3つのモードがあります:
0はエクスポートモード
1はインポートモード
2はリンクモード(フルアップ日付) 機能)
ここで特に説明したいのは、IMEX パラメーターです。異なるモードは異なる読み取り動作と書き込み動作を表すためです。
IMEX=0 の場合、このモードで開かれた Excel ファイルのみが使用できます。 「書く」目的のため。
IMEX=1の場合は「インポートモード」となり、このモードで開いたExcelファイルは「読み込み」のみに使用できます。
IMEX=2の場合、このモードで開かれたExcelファイルは「読み取り」と「書き込み」の両方の目的に対応できます。
の意味は次のとおりです:
0 ---出力モード;
2 ---リンクモード (完全な更新機能)
フォロー上記の説明では、接続文字列はプラグイン


によって読み取り可能および記録可能である必要がありますが、そうではありません。 Insert Into ステートメントが実行されると、例外が発生します。「操作は更新可能オブジェクトを使用する必要があります。」

クエリ」!
これは Web アプリケーションではなく C# WinForm プログラムであることに注意してください。

Web アプリケーションの場合は、IIS_IUSRS または IIS_Service ユーザーのディレクトリ アクセス許可を追加する必要があります。

または検索してください。他の人がどのように問題を解決したかを見てみましょう。しかし、他の人の問題の解決方法を見た後、それはここでのテストに合格しません。
やはり IMEX 値に問題があるようです。1 に変更しても機能しない場合は、0 に変更してください。

ニマ、奇跡が起こりました!

その後、IMEX を 4 または 10 に設定してテストしましたが、結果は 1 と 2 を除いてすべて問題ありませんでした。これは本当に不正なリズムです。

以上がC# が oledb を使用して Excel に接続し、Insert Into ステートメントを実行する「更新可能なクエリを使用する必要がある」という問題を解決するサンプル コードです。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C# を使用した Active Directory C# を使用した Active Directory Sep 03, 2024 pm 03:33 PM

C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# シリアル化 C# シリアル化 Sep 03, 2024 pm 03:30 PM

C# シリアル化のガイド。ここでは、C# シリアル化オブジェクトの導入、手順、作業、例についてそれぞれ説明します。

C# の乱数ジェネレーター C# の乱数ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の乱数ジェネレーターのガイド。ここでは、乱数ジェネレーターの仕組み、擬似乱数の概念、安全な数値について説明します。

C# データ グリッド ビュー C# データ グリッド ビュー Sep 03, 2024 pm 03:32 PM

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実装とともに説明します。

C# の素数 C# の素数 Sep 03, 2024 pm 03:35 PM

C# の素数ガイド。ここでは、C# における素数の導入と例を、コードの実装とともに説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実装とともに説明します。

マルチスレッドと非同期C#の違い マルチスレッドと非同期C#の違い Apr 03, 2025 pm 02:57 PM

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。

See all articles