Heim Backend-Entwicklung C#.Net-Tutorial C# verwendet oledb, um eine Verbindung zu Excel herzustellen und die Insert Into-Anweisung auszuführen. Der Beispielcode der Lösung „muss eine aktualisierbare Abfrage verwenden' wird angezeigt

C# verwendet oledb, um eine Verbindung zu Excel herzustellen und die Insert Into-Anweisung auszuführen. Der Beispielcode der Lösung „muss eine aktualisierbare Abfrage verwenden' wird angezeigt

Mar 13, 2017 pm 05:46 PM

Die Umgebung, in der der Fehler auftrat: Windows 7, Framework 4, 0, Microsoft Office 2007, VS2010, c# WinFürm

Teil von Code:


                    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");
                        }
Nach dem Login kopieren


Das erste, was einem in den Sinn kommt, wenn man auf diesen Fehler stößt, ist, dass es keine Berechtigung gibt, sondern ausgeführt wird als Ein Administrator ist immer noch derselbe Fehler!

Berechtigungen durch den folgenden Code hinzugefügt, aber immer noch der gleiche Fehler:

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);
Nach dem Login kopieren

Knowledge-Tutorial, hier gibt es weitere Verbindungs-Strings: Extended Properties='Excel 12.0 ; HDR=ja; IMEX=2'


Wert des Parameters HDR:

HDR=Ja, was bedeutet, dass die erste Zeile der Titel ist und nicht als Daten verwendet wird. Wenn HDR=NO verwendet wird, bedeutet dies, dass die erste Zeile nicht der Titel ist und nicht als Daten verwendet wird. Der Systemstandard ist JA
Parameter Excel 8.0 Für Excel 97 und höher bis 2003 verwenden Sie Excel 8.0 und für 2007 oder 2010 verwenden Sie Erweiterte Eigenschaften=Excel 12.0

IMEX-Einstellungen (IMport EXport-Modus)
 IMEX verfügt über drei Modi:
 0 ist Exportmodus
 1 ist Importmodus
 2 ist verknüpfter Modus (vollständige Datumsfunktionen)
I Was hier einer besonderen Erklärung bedarf, ist der IMEX-Parameter, da verschiedene Modi unterschiedliche Lese- und Schreibverhalten darstellen:
Wenn IMEX=0, handelt es sich um den „Exportmodus“. Die Excel-Datei kann nur in diesem Modus geöffnet werden für „Schreibzwecke“ verwendet werden.
Wenn IMEX=1, handelt es sich um den „Importmodus“. Die in diesem Modus geöffnete Excel-Datei kann nur zum „Lesen“ verwendet werden.
Wenn IMEX=2, handelt es sich um den „Link-Modus“. Die in diesem Modus geöffnete Excel-Datei kann sowohl „Lesen“ als auch „Schreiben“ unterstützen.
bedeutet wie folgt:
0 ---Ausgabemodus;
1---Eingabemodus; > 2----Link-Modus (vollständige Aktualisierungsfähigkeit)

Gemäß der obigen Beschreibung sollte die obige Verbindungszeichenfolge vom Plug-in lesbar und aufgezeichnet werden


Aber das ist nicht der Fall. Wenn die Insert Into-Anweisung ausgeführt wird, tritt eine Ausnahme auf: „Der Vorgang muss eine aktualisierbare Abfrage verwenden.“ !

Beachten Sie, dass es sich um ein C#-WinForm-Programm und nicht um eine Webanwendung handelt. Wenn es sich um eine

Webanwendung handelt, müssen Sie die Verzeichniszugriffsberechtigungen hinzufügen des IIS_IUSRS- oder IIS_Service-Benutzers;

Es ist besser zu suchen und zu sehen, wie andere das Problem gelöst haben , aber ich habe alle anderen gelesen. Die Methode zur Lösung des Problems hat den Test nicht bestanden, als es um mich ging!

Ich schätze, es ist immer noch ein Problem mit dem IMEX-Wert. Wenn das Ändern auf 1 nicht funktioniert, dann ändern Sie es auf 0.

Verdammt, ein Wunder ist passiert!

Dann habe ich versucht, IMEX auf 4 oder 10 zu setzen, und die Ergebnisse waren alle in Ordnung, bis auf 1 und 2. Es war wirklich ein Schummelrhythmus.

Das obige ist der detaillierte Inhalt vonC# verwendet oledb, um eine Verbindung zu Excel herzustellen und die Insert Into-Anweisung auszuführen. Der Beispielcode der Lösung „muss eine aktualisierbare Abfrage verwenden' wird angezeigt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles