Here's a solution - using execute process.
It works for all install variants of MS SQL
(with 100-170)
function ExecuteProcess(const FileName, Params: string;
Folder: string; WaitUntilTerminated, WaitUntilIdle, RunMinimized: Boolean;
var ErrorCode: Integer): Boolean;
var
cmdLine: string;
WorkingDirP: PChar;
StartupInfo: TStartupInfo;
ProcessInfo: TProcessInformation;
begin
Result := true;
cmdLine := '"' + FileName + '" ' + Params;
if Folder = '' then
Folder := ExcludeTrailingPathDelimiter(ExtractFilePath(FileName));
ZeroMemory(@StartupInfo, SizeOf(StartupInfo));
StartupInfo.cb := SizeOf(StartupInfo);
if RunMinimized then
begin
StartupInfo.dwFlags := STARTF_USESHOWWINDOW;
StartupInfo.wShowWindow := SW_SHOWMINIMIZED;
end;
if Folder <> '' then
WorkingDirP := PChar(Folder)
else
WorkingDirP := nil;
if not CreateProcess(nil, PChar(cmdLine), nil, nil, false, 0, nil,
WorkingDirP, StartupInfo, ProcessInfo) then
begin
Result := false;
ErrorCode := GetLastError;
exit;
end;
with ProcessInfo do
begin
CloseHandle(hThread); // CHECK - CLOSE HERE? or move line down?
if WaitUntilIdle then
WaitForInputIdle(hProcess, INFINITE);
// CHECK ::WaitUntilTerminated was used in C++ sqlcmd.exe
if WaitUntilTerminated then
repeat
Application.ProcessMessages;
until MsgWaitForMultipleObjects(1, hProcess, false, INFINITE, QS_ALLINPUT)
<> WAIT_OBJECT_0 + 1;
CloseHandle(hProcess);
// CHECK :: CloseHandle(hThread); was originally placed here in C++ ...
end;
end;
procedure TestForsqlCmd();
var
errCode: Integer;
success: Boolean;
begin
success := ExecuteProcess('sqlcmd.exe', '-?', '', true, true, true, errCode);
if not success then
begin
s := 'The application ''sqlcmd.exe'' wasn''t found!' + sLineBreak +
'The MS SQLEXPRESS utility is missing.' + sLineBreak +
'Press EXIT when ready.';
MessageDlg(s, TMsgDlgType.mtError, [mbOk], 0);
exit;
end;
end;
sqlcmd.exe -?
in a process in your C# app - if it works, then SQLCMD is present - if not, it'll tell you something like "file not found" or "command invalid" or something .... – Livvy