大数据对象 - 我是否担心太多了

本文关键字:担心 太多 是否 数据 对象 | 更新日期: 2023-09-27 18:37:00

我是第一次使用 EF,所以我不知道这种情况是否正常,或者我有严重的性能问题。
我有以下情况:

波纹管是我的课程。项目是这里的主要对象。因此,当我从数据库中提取项目列表时,我得到例如 1000 个项目。现在,每个项目都有所有属性与数据一起归档。城市包含国家,国家包含城市列表,用户有创建项目的列表,每个项目都有数据,城市,城市有国家,国家城市列表等...
也许我太担心了,我不知道这个对象应该包含所有这些数据,这是否会产生性能问题,或者我在这里做错了什么?

public abstract class Item
    {
        [Key]
        public int ItemId { get; set; }
        public int ItemTypeId { get; set; }
        public Guid UserId { get; set; }
        public DateTime CreatedOnDate { get; set; }
        public string Title { get; set; }
        public string Description { get; set; }
        public int? MediaId { get; set; }
        public int CityId { get; set; }
        public virtual City City { get; set; }
        public virtual User User { get; set; }
        public virtual ICollection<ItemInBoard> ItemsInBoard { get; set; }
        public virtual ICollection<Like> Likes { get; set; }
        public virtual ICollection<Comment> Comments { get; set; }        
    }
public class City
    {
        public int CityId { get; set; }
        public string Name { get; set; }
        public double Longitude { get; set; }
        public double Latitude { get; set; }
        public int CountryId { get; set; }
        public virtual Country Country { get; set; }
    }
public class Country
    {
        public int CountryId { get; set; }
        public string Name { get; set; }
        public string CountryCode { get; set; }
        public virtual ICollection<City> Cities { get; set; }
    }
public class User
    {
        public Guid UserId { get; set; }
        public string FirstName { get; set; }
        public string LastName { get; set; }
        public bool Gender { get; set; }
        public DateTime? BirthDay { get; set; }
        public string AboutMe { get; set; }
        public int? MediaId { get; set; }
        public int CityId { get; set; }
        public virtual City City { get; set; }
        public virtual ICollection<Item> Items { get; set; }
        public virtual ICollection<Board> Boards { get; set; }
        public virtual ICollection<Like> Likes { get; set; }
    }

大数据对象 - 我是否担心太多了

这取决于

你。 这是一个称为延迟加载的概念。 您可以使用以下代码启用或禁用延迟加载:

  context.Configuration.LazyLoadingEnabled = false;
  context.Configuration.LazyLoadingEnabled = true;

启用此选项时,不会加载任何依赖实体。 若要强制加载依赖实体,可以使用包含 lambada 表达式,如下所示:

   var test = context.Tests.Include("SomeOtherDependentEntity");

希望我得到你,这就是你的意思。

我想说的是,您拥有的东西对于一般业务逻辑来说很好。

当我必须以只读方式进行大量时间敏感的处理时,我会使用这样的SQL命令来准确且仅获得我想要的内容。

public class myQueryClass
{
public string Property1 { get; set; }
public string Property2 { get; set; }
}
var context = new MyDbContext();
context.Database.SqlQuery<myQueryClass>("SELECT Property1 = acolumn, Property2 = acolumn2 FROM myTable WHERE something = somestate");