


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
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"); }
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);
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)
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.“ !
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!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen





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.

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

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

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.

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.

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.

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 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.
