我有一个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>
之前有没有人遇到过这个问题或类似问题?解决方案是什么?
我欢迎任何可能有助于此的建议。
谢谢,
尤金
答案 0 :(得分:0)
我认为Server
属性应该只是'(localdb)\MsSqlLocalDb'
。
还要确保在运行安装程序时LocalDB实例存在,并且它与运行安装程序的用户共享。 出于测试目的,您还可以尝试使用命名管道而不是服务器名称。要获取实例管道的名称,请在命令行中运行以下命令:
sqllocaldb info MsSqlLocalDb
答案 1 :(得分:0)
WiX不支持localdb连接。
https://github.com/wixtoolset/issues/issues/4957
有人必须更新dutil才能使用最新的SQL Server Native Client,并且似乎在7年内没有人使用。
替代方法是编写自己的自定义操作以进行SQL处理。如果您通过电子邮件将请求发送给我,我可以提供一些帮助。