从命令行运行xml文件(Analysis Services)



我正在寻找工具或一个简单的方法来运行xml脚本(例如创建或删除多维数据集)。我曾经使用Inno Setup程序制作exe文件,在那里我可以编写命令,可以运行另一个exe文件,就像在命令行中一样。

我发现有这样的工具,如ascmd.exe (Ascmd命令行实用程序示例的自述文件)。但它在旧版本的MS SQL中使用。还有其他的MS SQL Server 2012和更新的版本吗?

我可以说我没有使用ascmd.exe工具,因为我无法获得这个工具(我无法从这里用c#编译项目:Ascmd命令行实用程序示例自述)。

我用c#写了我自己的exe文件,我可以从命令行运行。也许我的代码会帮助类似的问题的人。:)

using Microsoft.AnalysisServices;
string cubeServerName = args[1];    
string cubeName = args[2];  
Server server = null;
try
{
    server = new Server();
    server.Connect("Data source=" + cubeServerName + ";Timeout=7200000;Integrated Security=SSPI;");
}
catch (Exception e)
{
    return (int)ExitCode.UnknownError;
}
string sqlServerName = args[3]; 
string user = args[4];
string pass = args[5];
string path = args[6];
string xmlaScript = "";
try
{
    xmlaScript = System.IO.File.ReadAllText(@path);
}
catch (Exception e)
{
    return (int)ExitCode.InvalidFilename;
}
if (server != null)
{
    try
    {
        int exitCode = 0;
        if (xmlaScript != "")
            exitCode = ServerExecute(server, xmlaScript);
        server.Disconnect();
        return exitCode;
    }
    catch (Exception e)
    {
        return (int)ExitCode.UnknownError;
    }
}
//...
private static int ServerExecute(Server server, string command)
{
    XmlaResultCollection results = server.Execute(command);
    foreach (XmlaResult result in results)
    {
        foreach (XmlaMessage message in result.Messages)
        {
            if (message is XmlaError)
            {
                Console.WriteLine("ERROR: {0}", message.Description);
                return (int)ExitCode.UnknownError;
            }
            else
            {
                System.Diagnostics.Debug.Assert(message is XmlaWarning);
                Console.WriteLine("WARNING: {0}", message.Description);
            }
        }
    }
    return (int)ExitCode.Success;
}

我建议您下载ASCMD_StressTestingScripts(其中包含Ascmd.exe):https://sqlsrvanalysissrvcs.codeplex.com/releases

然后在与Ascmd.exe相同的目录下创建一个包含以下内容的Ascmd.exe.config文件。这将导致它使用SQL 2014。如果您想要SQL 2012,请将12.0.0.0更改为11.0.0.0:

<configuration>
   <runtime>
      <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
         <dependentAssembly>
            <assemblyIdentity name="Microsoft.AnalysisServices" publicKeyToken="89845dcd8080cc91" />
            <bindingRedirect oldVersion="10.0.0.0" newVersion="12.0.0.0" />
            <publisherPolicy apply="no" />
         </dependentAssembly>
      </assemblyBinding>
   </runtime>
</configuration>

相关内容

  • 没有找到相关文章

最新更新