我正在将我的网络应用程序从.Net Core 1.1
迁移到2.0
,并试图通过确保它在1.1和2.0下工作来使其更兼容。
在使项目包自动适应当前切换版本时,我在.csproj文件中使用了<Choose/>
和<When/>
标记,如下所示:
<Choose>
<When Condition="'$(TargetFramework)' == 'netcoreapp1.1'">
<ItemGroup>
<PackageReference Include="..." Version="1.1.2" />
<!-- Some package references -->
</ItemGroup>
<ItemGroup>
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="1.1.0-preview4-final" />
</ItemGroup>
</When>
<When Condition="'$(TargetFramework)' == 'netcoreapp2.0'">
<ItemGroup>
<PackageReference Include="Microsoft.AspNetCore.All" Version="2.0.0" />
<PackageReference Include="Swashbuckle.AspNetCore" Version="1.0.0" />
</ItemGroup>
<ItemGroup>
<DotNetCliToolReference Include="Microsoft.VisualStudio.Web.CodeGeneration.Tools" Version="2.0.0" />
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="2.0.0" />
</ItemGroup>
</When>
</Choose>
这适用于<PackageReference/>
s,应用程序编译良好并在指定的$(TargetFramework)
下运行。
但是, dotnet cli工具似乎缺少&#34;&#34;从这个行动的项目。执行dotnet restore
命令后,我尝试dotnet ef database udpate
命令,最终收到此消息:
找不到匹配命令&#34; dotnet-ef&#34;
的可执行文件
然而,当我从<DotNetCliToolReference/>
标记中取出<Choose></Choose>
并运行dotnet restore
时,一切都表现得很好。
那么,在dotnet-cli中运行时,这些标签的问题是什么?我可以做些什么让我的dotnet-cli ItemGroup根据$(TargetFramework)
自动更改?
答案 0 :(得分:0)
DotNetCliToolReference独立于csproj文件中的目标框架。每个csproj文件只能有一个版本的Microsoft.EntityFrameworkCore.Tools.DotNet,并且不能有条件地包含它。删除选择/何时使dotnet-ef工作。