我已经创建了一个类“ProductPart”,其中将在Sql中创建这些实体。
public class ProductPart : ContentPart
{
public decimal UnitPrice { get; set; }
public string Sku { get; set; }
}要在SQL中表示这些实体,我们必须遍历Migrations,类如下所示
public class Migrations : DataMigration
{
private readonly IContentDefinitionManager _contentDefinitionManager;
public Migrations(IContentDefinitionManager contentDefinitionManager)
{
this._contentDefinitionManager = contentDefinitionManager;
}
public int Create()
{
CreateTable();
UpdateForm1();
return 1;
}
private void CreateTable()
{
SchemaBuilder.CreateTable(nameof(ProductPart), table => table
.Column<int>("Id", column => column.PrimaryKey().NotNull())
.Column<decimal>("UnitPrice")
.Column<string>("Sku", column => column.WithLength(50))
);
}
private void UpdateForm1()
{
_contentDefinitionManager.AlterPartDefinition(nameof(ProductPart), part =>
part.Attachable()
.WithDisplayName("Product")
.WithDescription("Add products to the content."));
}
}在启动类中,我创建了一个范围实例,它是
public void ConfigureServices(IServiceCollection services)
{
services.AddContentPart<ProductPart>();
services.AddScoped<IDataMigration, Migrations>();
services.AddOrchardCms();
}最后,当我运行这个程序时,我得到了下面的错误。
*>某些服务无法构造(验证时出错)
服务描述符'ServiceType: OrchardCore.Data.Migration.IDataMigration生命周期:作用域ImplementationType: OrchardWebSiteModule.Migrations':在试图激活‘OrchardWebSiteModule.Migrations’时无法解析类型为OrchardCore.Data.Migration.IDataMigration的服务。
发布于 2021-04-06 07:41:18
我和你遇到了同样的问题,过了一段时间,我找到了一个可能对你有帮助的解决方案。首先,您可以在Github 链接上引用此问题。因此,按照对这个问题的解释,您需要在自定义模块中的Manifest.cs文件中启用内容模块,下面是我的Manifest.cs文件:
在此之后,您还需要一个步骤:将这一行services.AddScoped<IDataMigration, Migrations>();从应用程序中的Startup.cs移动到自定义模块中的行。我不知道确切原因是什么,但我猜主应用程序中没有启用内容模块。
https://stackoverflow.com/questions/65291494
复制相似问题