How to Efficiently Execute Large SQL Scripts with GO Commands in C#?
Jan 20, 2025 am 01:46 AMUse GO command to efficiently execute large SQL scripts
When executing large SQL scripts in C# that contain multiple batches separated by GO statements, the built-in SqlCommand.ExecuteNonQuery() method may encounter errors while processing these statements.
A better way
Consider using SQL Server Management Objects (SMO), which supports GO delimiters. This approach is more efficient and provides a seamless execution experience.
Implementation details
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); } } }
Alternative methods
If SMO is not available, consider using the library written by Phil Haack for handling GO delimiters:
https://www.php.cn/link/3cdad14c5d7c1e1fa307772a876b42d7
The above is the detailed content of How to Efficiently Execute Large SQL Scripts with GO Commands in C#?. For more information, please follow other related articles on the PHP Chinese website!

Hot Article

Hot tools Tags

Hot Article

Hot Article Tags

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

What are the types of values returned by c language functions? What determines the return value?

What are the definitions and calling rules of c language functions and what are the

C language function format letter case conversion steps

Where is the return value of the c language function stored in memory?

How do I use algorithms from the STL (sort, find, transform, etc.) efficiently?

How does the C Standard Template Library (STL) work?
