Wix SqlDatabase创建2014 LocalDb错误

问题描述 投票:1回答:2

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

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

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

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

从安装程序日志中: 动作11:46:34:CreateFolders。创建文件夹 CreateFolders:文件夹:C:\ Check \ Database \ CreateFolders:文件夹: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>

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

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

谢谢, 尤金

wix localdb
2个回答
0
投票

我相信Server属性应该只是'(localdb)\MsSqlLocalDb'

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

sqllocaldb info MsSqlLocalDb

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处理编写自己的自定义操作。如果您通过电子邮件向我发送请求,我可以提供一些。

© www.soinside.com 2019 - 2024. All rights reserved.