首页 / C# / c# – 实体框架和自引用表
c# – 实体框架和自引用表
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c# – 实体框架和自引用表,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1122字,纯文字阅读大概需要2分钟。
内容图文
![c# – 实体框架和自引用表](/upload/InfoBanner/zyjiaocheng/784/b96bb3d2065b481a8b703d19f49889a3.jpg)
我需要一个以一个名为“User”的表开头的数据库,该表需要自我引用,并且会有一个非常深的相关对象图.它需要像下面图像的左侧(忽略右侧).
我还需要向上和向下遍历此图表以计算百分比,总计等.换句话说,在某些情况下我需要遍历整个图表.
这是可能的和/或它是如何完成的?可以在LINQ语句中直接进行遍历吗?例子?
编辑:
我基本上试图创建一个网络营销场景,并需要计算每个人的收入.
例子:
>能够计算特定用户下每个用户的总销售额(因此每个用户都会有某种收入).
>计算树木某一级别的佣金(例如,如果顶级人员下面有3人,每人以1美元的价格出售产品,佣金为50%,则会有1.50美元.)
>如果我查询上面(左边)的图像为“B”,我应该得到“B,H,I,J,N,O”
希望这有助于:S
解决方法:
您不能仅使用LINQ遍历整个树,这种方式可以转换为单个SQL查询(或者它们的常量计数).您可以使用每个级别的一个查询或使用一个查询来执行此操作,该查询仅限于特定的级别计数(但是这样的查询会在很多级别上变得非常大).
在T-SQL中(我假设您使用的是MS SQL Server),您可以使用recursive common table expressions执行此操作.应该可以将其放入可以从LINQ使用的存储过程中以获取您实际需要的信息.
总而言之,您的选择是:
>不要使用LINQ,只使用递归CTE的SQL
>在LINQ的存储过程中使用递归CTE
>使用LINQ,为每个级别创建一个查询
>使用丑陋的LINQ查询仅限于几个级别
内容总结
以上是互联网集市为您收集整理的c# – 实体框架和自引用表全部内容,希望文章能够帮你解决c# – 实体框架和自引用表所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。