Linq To Nhibernate 中的子查询问题

发布于 2024-11-29 15:12:04 字数 944 浏览 4 评论 0原文

我有两个类

(按名称):人员和资产

(按关系类型):一对多(一个人由多个资产)

我使用 linq.Nhibernate 2.2 通过子查询编写了一个查询

var sub_q = from Asset a in SessionInstance.Linq<Asset>()                        
            select a.Person.Id;            

var q = from Person p in SessionInstance.Linq<Person>()
        where(sub_q.Contains(p.Id))
        select p;                

List<Person> list = q.ToList<Person>();

我在执行时间中看到一个异常 异常消息是:代码应该无法访问

当然以下查询是正确的

var sub_q = from Asset a in SessionInstance.Linq<Asset>()                        
            select a.Person.Id;
List<Person> personList = sub_qsub_q.ToList<Person>;
var q = from Person p in SessionInstance.Linq<Person>()
        where (personList.Contains(p.Id))
        select p;                

List<Person> list = q.ToList<Person>();

,但对性能没有好处

I have two classes

by Names : Person and Asset

by Relation type : One To Many (one person by many asset)

I wrote a query by subquery using linq.Nhibernate 2.2

var sub_q = from Asset a in SessionInstance.Linq<Asset>()                        
            select a.Person.Id;            

var q = from Person p in SessionInstance.Linq<Person>()
        where(sub_q.Contains(p.Id))
        select p;                

List<Person> list = q.ToList<Person>();

I see one Exception in Execution time
Message of exception is : Code supposed to be unreachable

Of course following query is true

var sub_q = from Asset a in SessionInstance.Linq<Asset>()                        
            select a.Person.Id;
List<Person> personList = sub_qsub_q.ToList<Person>;
var q = from Person p in SessionInstance.Linq<Person>()
        where (personList.Contains(p.Id))
        select p;                

List<Person> list = q.ToList<Person>();

But not is good for Performance

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

冷︶言冷语的世界 2024-12-06 15:12:04

只要做

var q= (from Asset a in SessionInstance.Linq<Asset>()                        
        select a.Person).ToList();

Just do

var q= (from Asset a in SessionInstance.Linq<Asset>()                        
        select a.Person).ToList();
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文