> 백엔드 개발 > C++ > C#에서 여러 문이 포함된 .SQL 스크립트 파일을 어떻게 실행할 수 있나요?

C#에서 여러 문이 포함된 .SQL 스크립트 파일을 어떻게 실행할 수 있나요?

Patricia Arquette
풀어 주다: 2025-01-18 15:12:10
원래의
425명이 탐색했습니다.

How Can I Execute an .SQL Script File with Multiple Statements in C#?

C#을 사용하여 .SQL 스크립트 파일 실행

C#에서 여러 문이 포함된 .SQL 파일을 실행하려면 ODP.NET의 ExecuteNonQuery 메서드에 대한 대안이 필요합니다. 이 문서에서는 이 작업을 수행하는 두 가지 방법을 설명합니다.

방법 1: SQL Server 관리 개체(SMO) 사용

  1. SqlConnection을 사용하여 데이터베이스 연결을 설정합니다.
  2. 연결을 사용하여 서버 개체를 초기화합니다.
  3. Server.ConnectionContext.ExecuteNonQuery(스크립트)를 사용하여 스크립트를 실행하세요.
<code class="language-csharp">using Microsoft.SqlServer.Management.Smo;
using Microsoft.SqlServer.Management.Common;
using System.IO;
using System.Data.SqlClient;

SqlConnection conn = new SqlConnection(sqlConnectionString);
Server server = new Server(new ServerConnection(conn));
string script = File.ReadAllText(@"path/to/script.sql");
server.ConnectionContext.ExecuteNonQuery(script);</code>
로그인 후 복사

*방법 2: SQL을 호출하는 프로세스 생성Plus**

  1. Process 개체를 생성하고 UseShellExecute를 false로 설정합니다.
  2. 결과를 캡처하려면 표준 출력을 리디렉션하세요.
  3. FileName 속성을 "sqlplus"로 설정합니다.
  4. 데이터베이스 자격 증명과 스크립트 경로를 포함하도록 Arguments 속성을 설정합니다.
  5. 콘솔 창을 숨기려면 CreateNoWindow를 true로 설정하세요.
  6. 프로세스가 종료 코드 1을 반환하면 작업을 다시 시도하세요.
<code class="language-csharp">Process p = new Process();
p.StartInfo.UseShellExecute = false;
p.StartInfo.RedirectStandardOutput = true;
p.StartInfo.FileName = "sqlplus";
p.StartInfo.Arguments = string.Format("xx/xx@{0} @{1}", in_database, s);
p.StartInfo.CreateNoWindow = true;

bool started = p.Start();
while (p.HasExited == false)
{
    Application.DoEvents();
}

int exitCode = p.ExitCode;
if (exitCode != 0)
{
    ... // 错误处理
}</code>
로그인 후 복사

위 내용은 C#에서 여러 문이 포함된 .SQL 스크립트 파일을 어떻게 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿