相关疑难解决方法(0)

使用<sql:SqlScript>元素通过Wix运行SQL脚本文件

我是Wix Installer的新手。我有一个要求,我必须提供SQL Server登录凭据并从特定路径运行脚本。

我没有发现问题所在。该项目已成功构建并创建了.msi。运行它后,出现以下错误:

错误26204。错误-2147217900:无法执行SQL字符串,错误详细信息:'»'附近的语法不正确,SQL密钥:CreateUpsizingDatabase SQL字符串:ïprint转换(varchar(25),GetDate(),121)+'执行文件:SqlTest.sql'

我的Sql脚本文件如下:

打印convert(varchar(25),GetDate(),121)+'执行文件:SqlTest.sql'

下面是我的代码:

<?xml version="1.0" encoding="UTF-8"?>
<Wix xmlns="http://schemas.microsoft.com/wix/2006/wi"
     xmlns:util="http://schemas.microsoft.com/wix/UtilExtension"
     xmlns:sql="http://schemas.microsoft.com/wix/SqlExtension">
    <Product Id="*" Name="SqlTest" Language="1033" Version="1.0.0.0" Manufacturer="BLRSCCMCAS01" UpgradeCode="0931a445-07bf-4494-b130-a1f96155021f">
        <Package InstallerVersion="200" Compressed="yes" InstallScope="perMachine" />

        <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." />
        <MediaTemplate />

        <Feature Id="ProductFeature" Title="SqlTest" Level="1">
            <ComponentGroupRef Id="ProductComponents" />
        </Feature>

    <Binary Id="CreateUpsizingDatabase" SourceFile="C:\Temp\SqlTest.sql" />

    <util:User Id="SQLUser" Name="[User]" Password="[Password]" />

    <sql:SqlDatabase Id="SqlDatabase" Database="[MyDb]" Server="[Server]" User="SQLUser" />

    </Product>

    <Fragment>
        <Directory Id="TARGETDIR" Name="SourceDir">
            <Directory Id="ProgramFilesFolder">
                <Directory Id="INSTALLFOLDER" Name="SqlTest" />
            </Directory>
        </Directory>
    </Fragment>

    <Fragment>
        <ComponentGroup Id="ProductComponents" …
Run Code Online (Sandbox Code Playgroud)

database sql-server installer wix

5
推荐指数
1
解决办法
3856
查看次数

标签 统计

database ×1

installer ×1

sql-server ×1

wix ×1