exec xp_cmdshell bcp синтаксис
Я не могу найти правильный синтаксис для экспорта данных с именами столбцов, используя exec xp_cmdshell bcp в SQL Server Studio Management Studio. Я попробовал следующие варианты
EXEC xp_cmdshell bcp "select "a_id","b_id","c_id" union select a_id,b_id,c_id from tablename out
"\\network_path\a.txt" -c -Uusername -Ppassword -Sservername"
А также
EXEC xp_cmdshell bcp 'select 'a_id','b_id','c_id' union select a_id,b_id,c_id from tablename out
'\\network_path\a.txt' -c -Uusername -Ppassword -Sservername'
А также
EXEC xp_cmdshell bcp 'select "a_id","b_id","c_id" union select a_id,b_id,c_id from tablename out
"\\network_path\a.txt" -c -Uusername -Ppassword -Sservername'
А также
EXEC xp_cmdshell bcp "select 'a_id','b_id','c_id' union select a_id,b_id,c_id from tablename out
'\\network_path\a.txt' -c -Uusername -Ppassword -Sservername"
Я успешно использовал приведенную ниже команду для экспорта таблицы, однако мне также нужны имена столбцов.
bcp tablename out "\\network_path\a_test.txt" -c -Uusername -Ppassword -Sservername'
1 ответ
Решение
Хорошо, вам на самом деле нужно заказать строку заголовка, чтобы она появилась сверху. Это должно справиться с этим
EXEC xp_cmdshell 'bcp "select * from (select ''a_id'' as a_id,''b_id'' as b_id,''c_id'' as c_id union select a_id,b_id,c_id from tablename)q order by case a_id when ''a_id'' then 0 ELSE 1 END" queryout "\\networkpath\a.txt" -c -Uusername -Ppassword -Sservername -ddatabasename'