Heim  >  Artikel  >  Backend-Entwicklung  >  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

黄舟
黄舟Original
2017-03-13 17:46:372088Durchsuche

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)

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!

Stellungnahme:
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