2013-02-26 102 views
0

我已经写在一个批处理文件中FOLL SQL查询从远程服务器获取结果使用SQLCMD输出文件的时间戳推杆。在批处理文件

SQLCMD -S "ServerName -U "uer" -P "Pass" -W -d"Interface" -Q"select LEFT(Zone_Prefix,5)+case when RIGHT(Zone_prefix,1)='N' then '_NORTH_WING' ELSE '_SOUTH_WING' END AS [Zone Name],cnt as [Zone Count] from (SELECT LEFT([Zone Name], 6) AS Zone_Prefix,SUM([Zone Count]) cnt FROM [Interface].[dbo].[VwZoneCount] WHERE [Zone Name] IN ('EB2GFNMZ','EB2GFSMZ','EB2GFNZ1','EB2GFSZ1','EB21FNZ1','EB21FSMZ','EB21FSZ1','EB22FNZ1','EB22FSZ1','EB22FSMZ','EB23FNMZ','EB23FNZ1','EB23FNZ2','EB23FNZ3','EB23FSMZ','EB23FSZ1','EB23FSZ2','EB24FNMZ','EB24FNZ1','EB24FSMZ','EB24FSZ1','EB25FNMZ','EB25FNZ1','EB25FSMZ','EB25FSZ1','EB26FNMZ','EB26FNZ1','EB26FSMZ','EB26FSZ1','EB27FNZ1','EB27FSMZ') GROUP BY LEFT([Zone Name], 6))tbl" -s" " -o"Output_hvac.xls" 

我正在执行此查询在每4小时使用任务计划程序。目前,对于每次执行,结果都被覆盖。 我每次执行新的结果被追加或存放于不同的文件与时间戳后需要。 我主要关注的是把一个时间戳和保持所有先前执行的数据。

感谢

回答

1

添加时间戳到一个文件名当然是可能的,但它是在批量痛苦。

你追加的第一个选项是简单得多。消除你-o选项,然后使用追加重定向来代替。添加时间戳只需要一个重定向的ECHO语句。

>>"Output_hvac.xls" echo %date% %time% 
>>"Output_hvac.xls" SQLCMD ...your_options_minus_the_-o_option... 

>>"Output_hvac.xls" (
    echo %date% %time% 
    SQLCMD ...your_options_minus_the_-o_option... 
)