如何递归迭代实体的属性
假设这就是我数据库中的内容,
table Ancestor (
idAncestor int not null,
name varchar(20) not null,
)
table Descendant (
idDescendant int not null,
name varchar(20) not null,
Ancestor_idAncestor int not null
)
当 ADO.NET 为上述 2 个表生成实体对象时,我可以通过 Ancestors.First 访问 Ancestor 的 Descendant ().后代。
如果我要递归地迭代祖先的后代或后代的后代并打印出其 id 和 name ,以下是我的尝试
public void Iterate(Ancestor a)
{
Type t = a.GetType();
PropertyInfo[] props = t.GetProperties();
foreach(var prop in props){
// pseudo code here
if(prop is entitycollection)
{
// how do I convert prop to entity collection here??
foreach(var p in prop){
Iterate(p)
}
} else {
print prop.GetValue(a, null)
}
}
}
我的问题是尝试确定实体属性是否属于实体集合,如果是,则查找该集合所保存的类型,然后迭代该类型,依此类推。
谢谢
Suppose this is what I have in my database
table Ancestor (
idAncestor int not null,
name varchar(20) not null,
)
table Descendant (
idDescendant int not null,
name varchar(20) not null,
Ancestor_idAncestor int not null
)
When ADO.NET generates the entity object for the above 2 tables, I can access Descendant
of Ancestor
through Ancestors.First().Descendants
.
If I were to recursively iterate over an ancestor's descendant(s) or descendant's descendant(s) and print out its id
and name
, the following is my attempt
public void Iterate(Ancestor a)
{
Type t = a.GetType();
PropertyInfo[] props = t.GetProperties();
foreach(var prop in props){
// pseudo code here
if(prop is entitycollection)
{
// how do I convert prop to entity collection here??
foreach(var p in prop){
Iterate(p)
}
} else {
print prop.GetValue(a, null)
}
}
}
My problem is trying to figure out if a entity property is of entity collection, if it is, then find the type hold by the collection, then iterate over the type, and so on.
Thanks
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
这应该是您正在寻找的内容的粗略版本:
编辑
此代码来自我之前用于克隆实体的一些代码。就是这样(您可能需要修改它以考虑不复制映射到主键的属性)
This should be a crude version of what you're looking for:
EDIT
This code came from some code I had previously played around with for cloning entities. Here it is (you might have to modify it to also take into consideration not duplicating your properties thar are mapped to primary keys)