- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 .NET EFCore 3.0 - 查询类型已折旧,现在我们移至 "Keyless entity type"在 Entity Framework Core 3.0 中。
我的要求是使用新的 HasNoKey()
将多个只读 View 从 MS SQL 数据库映射到 DbContext。句法。
public class ReadonlyActionOnDb
{
OrdersDbContext Db; //need to pass in via constructor etc, just for demo code.
protected void PrintOrderItems()
{
var custItems = Db.vOrders.Where(i=> i.CustomerId == 10).SelectMany(i=> i.OrderItems);
foreach (OrderItemDto i in custItems ) Console.WriteLine(i.ProductName);
}
}
//part of the config shown...
public partial class OrdersDbContext: DbContext
{
public DbSet<OrderDto> vOrders { get; set; }
public DbSet<OrderDto> vOrderItems { get; set; }
protected void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<OrderItemDto>().HasNoKey().ToView("vOrderItems ","dbo");
//how do we automatically load the OrderItems into this?
modelBuilder.Entity<OrderDto>().HasNoKey().ToView("vOrders","dbo");
}
}
public class OrderDto
{
public int Id { get; set; }
public int CustomerId { get; set; }
public ICollection<OrderItemDto> OrderItems { get; set; }
}
public class OrderItemDto
{
public int Id { get; set; }
public string ProductName { get; set; }
}
Keyless entity types characteristics
Keyless entity types support many of the same mapping capabilities as regular entity types, like inheritance mapping and navigation properties. On relational stores, they can configure the target database objects and columns via fluent API methods or data annotations.
However, they are different from regular entity types in that they:
Cannot have a key defined.
Are never tracked for changes in the DbContext and therefore are never inserted, updated or deleted on the database.
Are never discovered by convention.
Only support a subset of navigation mapping capabilities, specifically:
They may never act as the principal end of a relationship.
They may not have navigations to owned entities
They can only contain reference navigation properties pointing to regular entities.
Entities cannot contain navigation properties to keyless entity types.
Need to be configured with .HasNoKey() method call.
May be mapped to a defining query. A defining query is a query declared in the model that acts as a data source for a keyless entity type.
最佳答案
您不能查询订单然后包含订单项目。但是您可以查询所有订单项目,其中父订单符合您的条件,然后包括父记录。
我最近发现了一种设计模式,其中您的“无键实体”仅包含其他数据库实体的主键。为它们中的每一个定义导航属性。
public class OrderDetailKeys{
public int OrderId { get; set; }
public int OrderDetailId { get; set; }
public virtual Order Order { get; set; }
public virtual OrderDetail OrderDetail { get; set; }
}
modelBuilder.Entity<OrderDetailKeys>(entity => {
entity.HasNoKey();
entity.ToView(null); // or real view name
entity.HasOne(e => e.Order)
.WithOne()
.HasForeignKey<OrderDetailKeys>(e => e.OrderId);
entity.HasOne(e => e.OrderDetail)
.WithOne()
.HasForeignKey<OrderDetailKeys>(e => e.OrderDetailId);
}
FromRawSql
定义可重用结果集中哪些记录可用。
public static IQuerable<OrderDetailKeys> ComplexQuery(DbContext context) =>
context.Set<OrderDetailKeys>()
.FromRawSql("select OrderId, Id as OrderDetailId from OrderDetail where <complex sql condition here>");
Where
进一步限制结果。健康)状况。然后
Include
或
Select
只有他们需要的列。
var details = ComplexQuery(context)
.Where(k => k.Order.CustomerId = ...)
.Include(k => k.OrderDetail)
.ToListAsync();
关于ef-core-3.0 - 在 EF Core 3.0 中 - 如何从 View 中加入相关的只读无 key 实体,以便加载相关实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58732138/
第一段代码工作正常,并给出了我需要的结果。我现在想做的是让它在 'as num' 上返回 3 个数字值对于“as num”上的 3 个不同值,对于同一列上的 3 个不同位置 SELEC
我想分析一些数据以编写定价算法。以下日期可用: 我需要三个变量/维度的函数/相关因子,它显示三个维度(pers_capacity、卧室数量、浴室数量)增长时中位数(价格)的变化。例如Y(#pers_c
正如标题所说 - 我的 Sprite Kit 游戏时不时地在后台崩溃,总是出现此错误 - Exception Type: EXC_BAD_ACCESS (SIGSEGV) Exception Sub
假设我尝试保存以下数据,并且Songs模型的name属性上设置了Phalcon \ Mvc \ Model \ Validator \ PresenceOf验证器 // Get an existing
我有一个 if 控件,如下所示; if (Directory.Exists(System.IO.Path.Combine(systemPath, "Reports", companyName))
有人可以告诉我我们使用 ReadLine() 从文件 (.txt) 中读取特定行吗?现在我想读取文件的全部内容(不仅仅是第一行)。为此我需要使用什么方法。我用谷歌搜索了很多,但找不到解决方案。 我的代
我相信在大学时我用从 C 派生的语言为 FPGA 编写了一个程序。我了解 VHDL 和 verilog 等语言。但是,我不明白的是程序员在使用哪个方面有多少选择?它依赖于FPGA吗?我将使用 Xili
我有一个 if 控件,如下所示; if (Directory.Exists(System.IO.Path.Combine(systemPath, "Reports", companyName))
如何在运行时更改 Dashcode (Javascript) 中图像对象的源? 我试过: var image = document.getElementById("image").object;ima
我有几个相互关联的类,它们将被多种不同的算法使用 例子: struct B; struct A { B* parent; }; struct B { std::vector child
我正在开发一个网站,用户在客户收到的表中输入金额,如果任何客户没有提供分期付款(金额),则用户不会在表中输入任何金额,并且用户希望获取违约者的信息客户以10天为基础。所以我的问题是应该定义什么表和属性
我试图从上一个条目中选择一个值,并每次将该数字加一。我让它工作到选择当前条目值(默认 1000)并递增 1 并重新插入该值(因此每次最终都是 1001)。我需要它来选择该字段的最后一个条目,这样它将变
我不擅长“制作”查询。假设这是我的数据库: artist pics ------------------- -
最近,我要为我的网站做一个即时通知系统。我听说 COMET 在这种情况下必不可少。 我已经搜索 PHP 和 Comet 一段时间了,但是,我发现的指南和文章似乎只是循环中的 ajax 请求。例如,有一
我正在开发一款 iOS 游戏,我希望 clown 在场景外生成,然后向下移动。我的想法是全部创建它们,并将它们以 360 像素的距离放置在不可见的场景中。 像这样: SKSpriteNode *clo
我有以下子订单表。 mysql> select * from suborder; +-------------+------------------+ | order_state | bookin
这可能是一个有点初学者的问题,但考虑到在 Java 中调试编码是相当相关的:什么时候编码与 String 对象相关? 假设我有一个要保存到文件中的字符串对象。 String 对象本身是否使用某种我应该
首先我想说我是 CPP 的新手(我从 cpp11 开始):)考虑以下实体:学生(名字+姓氏)和组(描述+更多学生)。我在 C++ 中创建了以下 2 个类: class Student { privat
我正在尝试在单击该复选框时同步更新我的数据库。我决定使用 aJax,但它似乎无法识别 ajax。 代码:将成为 Switch_Active(this.id) 函数的元素 ... Deactivat
我正在创建一个菜单。菜单如下。 $('.category').mouseover(function() { $(this).removeClass('category').addClass('cate
我是一名优秀的程序员,十分优秀!