집 >데이터 베이스 >MySQL 튜토리얼 >C#을 사용하여 여러 문이 포함된 SQL 스크립트 파일을 어떻게 실행할 수 있나요?
C#을 사용하여 .SQL 스크립트 파일 실행
이 프로그래밍 시나리오의 목표는 여러 줄에 걸쳐 있는 명령문을 포함하여 여러 SQL 문이 포함된 SQL 스크립트 파일을 실행하는 것입니다. ODP.NET과 같은 방법을 시도하고 프로세스를 통해 SQLplus를 생성했지만 실행 및 출력 캡처에 어려움을 겪고 있습니다. C#을 사용하여 문제를 해결하는 방법은 다음과 같습니다.
C#을 사용하여 .SQL 스크립트 파일을 효과적으로 실행하려면 다음 개선 사항을 고려하세요.
서버 이름, 데이터베이스 이름 및 인증 자격 증명을 지정하는 연결 문자열을 사용하여 데이터베이스 연결을 설정합니다.
.SQL 스크립트 파일의 내용을 문자열 변수로 읽어옵니다. 이를 통해 파일을 한 번 읽고 나중에 사용할 수 있도록 내용을 저장할 수 있습니다.
연결 개체를 매개변수로 제공하여 서버 개체를 인스턴스화합니다. 그러면 사용하려는 SQL Server 인스턴스의 표현이 생성됩니다.
Server 개체의 ConnectionContext 속성을 사용하여 명령 개체를 만듭니다. 그런 다음 SQL 문자열을 명령 개체의 ExecuteNonQuery 메서드에 전달하여 스크립트가 실행됩니다. 그러면 스크립트의 모든 명령문이 순차적으로 실행됩니다.
스크립트 실행이 완료된 후 리소스를 해제하기 위해 데이터베이스 연결을 닫습니다.
다음은 위 접근 방식을 보여주는 코드 조각입니다.
<code class="language-csharp">using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using Microsoft.SqlServer.Management.Smo; using Microsoft.SqlServer.Management.Common; using System.IO; using System.Data.SqlClient; public partial class ExcuteScript : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { // 请替换为您的连接字符串 string sqlConnectionString = @"Integrated Security=SSPI;Persist Security Info=False;Initial Catalog=ccwebgrity;Data Source=SURAJIT\SQLEXPRESS"; // 读取SQL脚本文件的内容 string script = File.ReadAllText(@"E:\Project Docs\MX462-PD\MX756_ModMappings1.sql"); // 建立数据库连接 SqlConnection conn = new SqlConnection(sqlConnectionString); // 创建服务器实例 Server server = new Server(new ServerConnection(conn)); // 执行SQL脚本 server.ConnectionContext.ExecuteNonQuery(script); // 关闭连接 conn.Close(); } }</code>
이러한 단계를 수행하면 C#을 사용하여 .SQL 스크립트 파일을 프로그래밍 방식으로 실행하여 모든 문이 올바르게 실행되고 정확한 결과를 얻을 수 있습니다.
위 내용은 C#을 사용하여 여러 문이 포함된 SQL 스크립트 파일을 어떻게 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!