У меня есть этот код TSQL, который выводит данные из таблиц, используя BCP. Это выглядит сложно, но просто создает строку @command, которая будет выполняться один раз для каждой таблицы, а затем BCP выдает записи таблицы на диск. Это хороший способ быстро сделать резервную копию всех данных таблицы. Ниже я показываю исправленную версию, которую немного легче читать.
set @command =
'if (''?'' <> ''[dbo].[sysdiagrams]'')
BEGIN;
create table #result (result nvarchar(2048) null );
declare @temp nvarchar(1000);
set @temp = ''' + @bcpPath + ' ' + @database + '.dbo.'' +
substring( ''?'', 8, len(''?'')- 8) +
'' out "' + @driveLetter + @drivePath +
'\'' + substring( ''?'', 8, len(''?'')- 8) +
''.out" -c -x -t"|" -Uuser -Ppassword'';
insert into #result (result)
exec xp_cmdshell @temp;
drop table #result;
END;'
exec sp_msforeachtable @command
@bcppath
- это C:\Program Files\Microsoft SQL Server\90\Tools\Binn\bcp.exe
, в котором есть пробел.
Без использования двойных кавычек вокруг пути ""
выдает ошибку 'C:\Program' is not recognized...
При использовании двойных кавычек выдает ту же ошибку. Используя двойные двойные кавычки "" ""
, он говорит: The filename, directory name, or volume label syntax is incorrect.
@ команда разрешает это при печати:
if ('?' <> '[dbo].[sysdiagrams]')
BEGIN;
create table #result (result nvarchar(2048) null );
declare @temp nvarchar(1000);
set @temp = '"C:\Program Files\Microsoft SQL Server\90\Tools\Binn\bcp.exe"
myDB.dbo.' +
substring( '?', 8, len('?')- 8) +
' out "E:\DataExports\' +
substring( '?', 8, len('?')- 8) + '.out" -c -x -t"|" -Uuser -Ppassword';
insert into #result (result)
exec xp_cmdshell @temp;
drop table #result;
END;
EDIT:
Как ни странно, я поставил ECHO ? &&
перед "путем", и он сработал (окруженный двойными кавычками) .... Почему?