gpt4 book ai didi

c# - 在 mvvm 问题中创建类结构

转载 作者:行者123 更新时间:2023-11-30 13:56:28 25 4
gpt4 key购买 nike

我有以下类(class):
项目

public class Item : INotifyPropertyChanged, IDataErrorInfo
{
private int? id;
public int? ID
{
get
{ return id; }
set
{ id = value; }
}

private string name;
public string Name
{
get
{ return name; }
set
{
if (value != name)
{
ClearError("Name");
if (string.IsNullOrEmpty(value) || value.Trim() == "")
SetError("Name", "Required Value");
name = value;
}
}
}
private List<MedicineComposition> medicineCompositions;
public List<MedicineComposition> MedicineCompositions
{
set { medicineCompositions = value; }
get { return medicineCompositions; }
}
}

药物成分

public class MedicineComposition : INotifyPropertyChanged, IDataErrorInfo
{
private int? id;
public int? ID
{
get
{ return id; }
set
{ id = value; }
}

private Item item;
public Item Item
{
get
{ return item; }
set
{
if (item != value)
{
ClearError("Item");
if (value == null)
SetError("Item", "Required Value");
item = value;
}
}
}
private Component component;
public Component Component
{
get
{ return component; }
set
{
if (component != value)
{
ClearError("Component");
if (value == null)
SetError("Component", "Required Value");
component = value;
}
}
}
}

Component 只有 idName
以及以下从数据库中获取数据并列出我的对象的函数:Item 类中的 GetItems

public static List<Item> GetAllItems
{
get
{
List<Item> MyItems = new List<Item>();
SqlConnection con = new SqlConnection(BaseDataBase.ConnectionString);
SqlCommand com = new SqlCommand("sp_Get_All_Item", con);
com.CommandType = System.Data.CommandType.StoredProcedure;
try
{
con.Open();
SqlDataReader rd = com.ExecuteReader();
while (rd.Read())
{
Item i = new Item();
if (!(rd["ID"] is DBNull))
i.ID = System.Int32.Parse(rd["ID"].ToString());
i.Name = rd["Name"].ToString();
i.MedicineCompositions = MedicineComposition.GetAllByItem(i);

MyItems.Add(i);
}
rd.Close();
}
catch
{
MyItems = null;
}
finally
{
con.Close();
}
return MyItems;
}
MedicalCompositions

中的

GetAllByItem

public static List<MedicineComposition> GetAllByItem(Item i)
{
List<MedicineComposition> MyMedicineCompositions = new List<MedicineComposition>();

SqlConnection con = new SqlConnection(BaseDataBase.ConnectionString);
SqlCommand com = new SqlCommand("sp_Get_ByItemID_MedicineComposition", con);
com.CommandType = System.Data.CommandType.StoredProcedure;
SqlParameter pr = new SqlParameter("@ID", i.ID);
com.Parameters.Add(pr);
try
{
con.Open();
SqlDataReader rd = com.ExecuteReader();
while (rd.Read())
{
MedicineComposition m = new MedicineComposition() { };
if (!(rd["ID"] is DBNull))
m.ID = Int32.Parse(rd["ID"].ToString());
if (!(rd["ComponentID"] is DBNull))
m.Component = Component.GetByID(Int32.Parse(rd["ComponentID"].ToString()));
m.Item = i;
MyMedicineCompositions.Add(m);
}
rd.Close();
}
catch
{
MyMedicineCompositions = null;
}
finally
{
con.Close();
}
return MyMedicineCompositions;
}

它就像使用 mvvm 因为它让你处理对象而不是 datatable,但是当我使用以前的类结构形状时,我有 以下问题:

  • 我在数据库的 Item 表中至少有 1000 条记录,所以当我调用 GetAllItems 时,我的性能很慢,尤其是当数据库不在本地计算机上时。
  • 我尝试在启动画面打开时加载 Items,这需要时间,但性能一般
  • 每次更新 Item 表时,我应该记得 GetAllItems 这么慢回来
    我的问题是我在创建时遇到的问题在哪里,这是在mvvm
  • 中构建类的最佳方式吗>

最佳答案

我认为您的用户不需要一目了然地看到所有 1000 个项目,甚至不需要数千个相关的组成和组件。

遇到这种情况我会:

  1. 过滤数据。向用户询问项目名称、类别或其他内容。
  2. 延迟加载。首先只加载(过滤的)项目。当用户选择一个 Item 切换到“Item details” View 并加载相关数据(成分和组件)。

关于c# - 在 mvvm 问题中创建类结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28260386/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com