Heim > Backend-Entwicklung > C++ > Wie führt man große SQL-Skripte effizient mit GO-Befehlen in C# aus?

Wie führt man große SQL-Skripte effizient mit GO-Befehlen in C# aus?

Susan Sarandon
Freigeben: 2025-01-20 01:46:13
Original
224 Leute haben es durchsucht

How to Efficiently Execute Large SQL Scripts with GO Commands in C#?

Verwenden Sie den GO-Befehl, um große SQL-Skripte effizient auszuführen

Beim Ausführen großer SQL-Skripts in C#, die mehrere durch GO-Anweisungen getrennte Batches enthalten, kann es bei der integrierten SqlCommand.ExecuteNonQuery()-Methode bei der Verarbeitung dieser Anweisungen zu Fehlern kommen.

Ein besserer Weg

Erwägen Sie die Verwendung von SQL Server Management Objects (SMO), das GO-Trennzeichen unterstützt. Dieser Ansatz ist effizienter und bietet eine nahtlose Ausführungserfahrung.

Implementierungsdetails

using Microsoft.SqlServer.Management.Smo;

// 示例代码:
public static void Main()      
{  
  string scriptDirectory = "c:\temp\sqltest\";
  string sqlConnectionString = "Integrated Security=SSPI;" +
  "Persist Security Info=True;Initial Catalog=Northwind;Data Source=(local)";
  DirectoryInfo di = new DirectoryInfo(scriptDirectory);
  FileInfo[] rgFiles = di.GetFiles("*.sql");
  foreach (FileInfo fi in rgFiles)
  {
    FileInfo fileInfo = new FileInfo(fi.FullName);
    string script = fileInfo.OpenText().ReadToEnd();
    using (SqlConnection connection = new SqlConnection(sqlConnectionString))
    {
      Server server = new Server(new ServerConnection(connection));
      server.ConnectionContext.ExecuteNonQuery(script);
    }
  }
}
Nach dem Login kopieren

Alternative Methoden

Wenn SMO nicht verfügbar ist, sollten Sie die von Phil Haack geschriebene Bibliothek für den Umgang mit GO-Trennzeichen verwenden:

https://www.php.cn/link/3cdad14c5d7c1e1fa307772a876b42d7

Das obige ist der detaillierte Inhalt vonWie führt man große SQL-Skripte effizient mit GO-Befehlen in C# aus?. 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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage