Wix SqlDatabase创建2014 LocalDb错误

时间:2015-10-23 22:25:40

标签: wix localdb

我有一个Wix Toolset项目需要将数据库安装到SqlServer 2014 LocalDb的现有安装中,而我根本没有成功。我在SO以及其他网站上广泛搜索了可能适用的示例或建议。到目前为止,我发现在我的项目中没有任何效果。

SqlServer本地数据库已经安装在系统上,可以从SQL Mgmt Studio进行访问。所有系统数据库都按预期显示,我可以在Mgmt Studio中创建一个新数据库。

我作为测试包含的文本文件确实正确安装在预期的文件夹中。

我收到的错误取决于我在SqlDatabase元素中定义的选项。

从安装程序日志中
动作11:46:34:CreateFolders。创建文件夹
CreateFolders:Folder:C:\ Check \ Database \
CreateFolders:Folder:C:\ Check \ Database \
行动11:46:34:InstallFiles。复制新文件
InstallFiles:File:TestFile.txt,Directory:C:\ Check \ Database \,Size:19
行动11:46:34:CreateDatabase。创建数据库
CreateDatabase:错误0x80004005:无法创建SQL数据库但仍然出错:未知错误,数据库:检查
行动11:46:51:RegisterProduct。注册产品

此安装的wxs文件:

<?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="Ach Check Database Installation" Language="1033" Version="1.0.0.0" Manufacturer="ACH Solutions" UpgradeCode="3828eaf7-528f-4006-9169-27bed44e79fe">
    <Package InstallerVersion="200" Compressed="yes" InstallScope="perMachine" />
    <MajorUpgrade DowngradeErrorMessage="A newer version of [ProductName] is already installed." />
    <MediaTemplate EmbedCab="yes"/>
    <Feature Id="CheckDb" Title="Check Database" Description="The Check Database" ConfigurableDirectory="INSTALLDIR" Level="1">
        <ComponentGroupRef Id="DatabaseComponents" />
    </Feature>
    <UIRef Id="WixUI_Mondo" />
</Product>  
<Fragment>
  <Directory Id="TARGETDIR" Name="SourceDir">
    <Directory Id="INSTALLDIR" Name="CheckDir" >
      <Directory Id="DatabaseFolder" Name="Database" />
    </Directory>
  </Directory>
</Fragment>
<Fragment>    
    <ComponentGroup Id="DatabaseComponents" Directory="DatabaseFolder">
        <Component Id='SqlComponent' Guid='53234257-65F1-4D58-B2CA-90308EC102FF'>
            <CreateFolder />
            <File Id="file_TestFile.txt" Source="E:\TestFile.txt"/>
        </Component>
        <Component Id="sql_SqlDatabase" Guid="B4D9CB63-B740-4860-89B6-1209D9A1A18E">
             <CreateFolder/>
             <sql:SqlDatabase Id='SqlDatabase'
                    Database='Check'
                    CreateOnInstall='yes'
                    Server='localhost\(localdb)\MsSqlLocalDb'
                    DropOnUninstall='no'
                    ContinueOnError='yes'>
                <sql:SqlFileSpec Id='sql_CheckDatabase' Filename='CheckDatabase.mdb' Name='CheckDatabase' Size='30MB' />
               <sql:SqlLogFileSpec Id='sql_CheckDatabase_Log' Filename='CheckDatabase_Log.ldb' Name='CheckDatabaseLog' Size='3MB' />
            </sql:SqlDatabase>
        </Component>      
    </ComponentGroup>
</Fragment>  
</Wix>

之前有没有人遇到过这个问题或类似问题?解决方案是什么?

我欢迎任何可能有助于此的建议。

谢谢,
尤金

2 个答案:

答案 0 :(得分:0)

我认为Server属性应该只是'(localdb)\MsSqlLocalDb'

还要确保在运行安装程序时LocalDB实例存在,并且它与运行安装程序的用户共享。 出于测试目的,您还可以尝试使用命名管道而不是服务器名称。要获取实例管道的名称,请在命令行中运行以下命令:

sqllocaldb info MsSqlLocalDb

答案 1 :(得分:0)

WiX不支持localdb连接。

https://github.com/wixtoolset/issues/issues/4957

https://social.msdn.microsoft.com/Forums/sqlserver/en-US/b5c9a1fa-75fc-41f2-a5d3-4b2b6ed4ebde/localdb-problem-unable-to-connection-via-localdbv110-but-can-via-named-paipes

有人必须更新dutil才能使用最新的SQL Server Native Client,并且似乎在7年内没有人使用。

替代方法是编写自己的自定义操作以进行SQL处理。如果您通过电子邮件将请求发送给我,我可以提供一些帮助。