簡體   English   中英

“sqlcmd.exe -S Instance USE ...”在命令行中工作,但我無法將其移動到 c # process

[英]"sqlcmd.exe -S Instance USE ..." work in command line, but I can't move it to c # process

我正在嘗試將此命令移至 C# 過程:

SQLCMD.EXE -S InstanceName
USE [master]
GO
CREATE DATABASE [Ek] ON
( FILENAME = N'C:\Program Files\Microsoft SQL 
Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\Ek_Primary.mdf' ),
( FILENAME = N'C:\Program Files\Microsoft SQL 
Server\MSSQL15.MSSQLSERVER\MSSQL\DATA\Ek_Primary.ldf' )
FOR ATTACH ;
GO
EXIT

我有:

try
{
     Process p = CreateProcess();
     p.StartInfo.FileName = @"C:\Program Files\Microsoft SQL Server\Client SDK\ODBC\170\Tools\Binn\SQLCMD.EXE";
     p.StartInfo.Arguments = "-S InstanceName" + "\n" +
     "USE [master]" + "\n" +
     "GO" + "\n" +
     "CREATE DATABASE [Ek] ON" + "\n" +
     "( FILENAME = N'C:\\Program Files\\Microsoft SQL Server\\MSSQL15.MSSQLSERVER\\MSSQL\\DATA\\Ek_Primary.mdf' )," + "\n" +
     "( FILENAME = N'C:\\Program Files\\Microsoft SQL Server\\MSSQL15.MSSQLSERVER\\MSSQL\\DATA\\Ek_Primary.ldf' )" + "\n" +
     "FOR ATTACH ;" + "\n" +
     "GO" + "\n" +
     "EXIT" + "\n";
     Console.WriteLine(p.StartInfo.Arguments);
     p.Start();
     var output = p.StandardOutput.ReadToEnd();
     var err = p.StandardError.ReadToEnd();
     Console.WriteLine("O: " + output);
     Console.WriteLine("E: " + err);
}
catch (Exception e) { Console.WriteLine(e.Message); ; }

它返回 err = Unexpected 參數。 進入 '-?' 求助。

我正在嘗試在 cmd.exe 上設置文件名並將路徑移動到 Arguments。但它會永遠等待響應並且不會退出 p.StandardOutput.ReadToEnd ();

我試圖單獨發送每一行代碼,但也沒有成功。

我在開始 p.StartInfo.Argument 時嘗試使用 /C,但它沒有任何改變。

感謝塞爾文的建議。 我做到了:

string sqlConnectionString = @"Integrated Security=SSPI;Persist Security Info=False;Data Source=InstanceName";
string script = File.ReadAllText(@"../../sql.sql");
Microsoft.Data.SqlClient.SqlConnection conn = new Microsoft.Data.SqlClient.SqlConnection(sqlConnectionString);
Server server = new Server(new ServerConnection(conn));
server.ConnectionContext.ExecuteNonQuery(script);

在 sql.sql 中,我添加了所有 sql 行。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM