使用Start-process启动LogParser进程,遇到错误

时间:2013-05-28 19:38:31

标签: logging powershell logparser start-process

我正在使用以下代码尝试使用Log Parser来启动并将我拥有的.csv文件的内容转储到SQL数据库中。我不得不尝试使用自定义函数去除非字母数字字符,以便可以动态创建列,因为最终目标是使用我提供的任何.csv文件。

以下是代码:

start-process -NoNewWindow -FilePath "C:\Program Files (x86)\Log Parser 2.2\LogParser.exe" -ArgumentList @"

"Create Function [dbo].[RemoveNonAlphaNumCharacters](@Temp VarChar(1000))
Returns VarChar(1000)
AS
Begin

    Declare @KeepValues as varchar(50) = '%[^a-z0-9]%'
    While PatIndex(@KeepValues, @Temp) > 0
        Set @Temp = Stuff(@Temp, PatIndex(@KeepValues, @Temp), 1, '')

    Return @Temp
End
SELECT.RemoveNonAlphaNumCharacters * INTO SQLCounters FROM C:\Users\SeanLon\Desktop\SQL_Log_0.csv" -i:CSV -o:SQL -server:MJNHNX4 -database:PerfmonCounters -driver:"SQL Server" -createTable:ON

"@

错误:

start-process : Process with an Id of 221104 is not running.
At C:\Users\seanlon\Desktop\Performance\Powershell examples\LogParser.ps1:1 char:1
+ start-process -NoNewWindow -FilePath "C:\Program Files (x86)\Log Parser 2.2\LogP ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [Start-Process], ArgumentException
    + FullyQualifiedErrorId : System.ArgumentException,Microsoft.PowerShell.Commands.StartProcessCommand

启动进程或日志解析器是不是只能处理参数列表中的SQL复杂?或者LogParser进程是否在其他事情发生之前就结束了?

2 个答案:

答案 0 :(得分:1)

在PowerShell 3.0上,它看起来像是干净利落地传递参数。但是,为了简化这一点,您可以将SQL放在文件foo.sql中,然后像这样调用logparser:

$logParser = "C:\Program Files (x86)\Log Parser 2.2\LogParser.exe"
& $logParser file:c:\foo.sql -i:CSV -o:SQL -server:MJNHNX4 -database:PerfmonCounters -driver:"SQL Server" -createTable:ON

答案 1 :(得分:0)

LogParser对数据库一无所知,它在内部引擎中解释并执行简单的SQL查询,而内部引擎不处理存储过程。另请参阅Logparser not recognizing SQL command