C# を使用して .SQL スクリプト ファイルを実行する方法 質問する

C# を使用して .SQL スクリプト ファイルを実行する方法 質問する

この質問はすでに回答されていると思いますが、検索ツールを使用しても回答を見つけることができませんでした。

c# を使用して .sql ファイルを実行したいと思います。sql ファイルには複数の sql ステートメントが含まれており、その一部は複数行に分割されています。ファイルの読み込みと、ODP.NET を使用してファイルの実行を試みましたが、ExecuteNonQuery は実際にはこれを実行するように設計されていないと思います。

そこで、プロセスの生成を介して sqlplus を使用しようとしましたが、UseShellExecute を true に設定してプロセスを生成しない限り、sqlplus はハングして終了しません。動作しないコードは次のとおりです。

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();
p.WaitForExit();

WaitForExit は、UseShellExecute を true に設定しない限り、決して戻りません。UseShellExecute の副作用は、リダイレクトされた出力をキャプチャできないことです。

ベストアンサー1

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";

        string script = File.ReadAllText(@"E:\Project Docs\MX462-PD\MX756_ModMappings1.sql");

        SqlConnection conn = new SqlConnection(sqlConnectionString);

        Server server = new Server(new ServerConnection(conn));

        server.ConnectionContext.ExecuteNonQuery(script);
    }
}

おすすめ記事