网站开发前期功能策划,模板网传奇手游,基于php网站开发设计,网站建设用什么程序一、导航属性数据加载
1.在EF Core中可以使用导航属性来加载相关实体。 2.加载实体的三种方式#xff1a; (1)预先加载#xff1a;直接在查询主体时就把对应的依赖实体查出来#xff08;作为初始查询的一部分#xff09; (2)显式加载#xff1a;使用代码指示稍后显式的从…一、导航属性数据加载
1.在EF Core中可以使用导航属性来加载相关实体。 2.加载实体的三种方式 (1)预先加载直接在查询主体时就把对应的依赖实体查出来作为初始查询的一部分 (2)显式加载使用代码指示稍后显式的从数据库中加载数据 (3)延迟加载在访问导航属性时以透明的方式加载关联数据
二、数据预加载
1.关联查询直接使用导航属性就可以访问关联数据但是不能直接以“.”去调用导航属性的数据否则会报错如示例代码所示 运行
原因是这里的导航属性Post只是起到一个完成约定配置的作用其本身在主体数据加载时并不会自动加载关联数据。 要通过导航属性来访问数据需要在DbSet的Include()方法来加载子数据。Include()接收两种与导航属性相关的参数。第一种是要加载的导航属性名的字符串第二种是直接通过Lambda表达式来进行加载 Lambda:
属性字符串
运行
2.多层级数据访问可以通过多次调用Include()方法实现深层数据加载以省市县数据为例 省
市
县区
在程序中使用Include与ThenInclude来实现多层级的数据加载
运行
注意使用Include加载数据只是指定在加载主体的时候把依赖实体一并带出来并赋值返回的实体依旧是最开始指定的DbSet。例如上面返回的就还是Province省但是省内的市级与县级数据也会被一并查询出来。
三、使用Include进行数据过滤
1.在使用Include进行数据加载时默认会加载主体实体所包含的所有依赖实体。但是某些时候我们不需要查询出所有的依赖实体而是只需要加载我们感兴趣的数据即可。 例如在上面的省-市-县三级联动查询中假如我只想查询辽宁省大连市的所有数据那么就需要在调用Include()时指定数据过滤。否则它将会加载整个辽宁省的数据。 2. 在调用Include()方法时可以使用Where等方法进行数据过滤同时可以对依赖实体进行排序等操作。
运行