首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >IN ()语句在NHibernate中是如何工作的?(使用条件)

IN ()语句在NHibernate中是如何工作的?(使用条件)
EN

Stack Overflow用户
提问于 2008-12-30 22:10:43
回答 1查看 800关注 0票数 2

我正在尝试使用NHibernate创建与下面类似的代码。我已经使用fluent完成了所有的映射,我可以很好地完成基本的查询,但是我不知道怎么做。

代码语言:javascript
运行
复制
-**Product Table**
Reference
Title
Subjects (Many to Many relationship)
Price

-**Subject table**
SubjectID
Name

-**SubjectToProductMapping Table**
Reference
SubjectID

现在我需要这样做:

代码语言:javascript
运行
复制
SELECT * 
FROM Product
WHERE Reference IN 
    (Select Reference FROM SubjectToProductMapping WHERE SubjectID = @SubjectID)

记住,Product表已经为post大大简化了,我更喜欢使用IN语句来保持查询的其余部分更简单。理想情况下,我希望使用条件创建查询,因为我将使用条件来对结果进行分页。

提前感谢

EN

回答 1

Stack Overflow用户

发布于 2009-01-02 21:46:28

如果连接就足够了,为什么还要使用in呢?如果您的Products类有一个映射的主题集合,那么您可以只使用以下条件

代码语言:javascript
运行
复制
IList<Product> results = session.CreateCriteria(typeof(Product))
                                .CreateCriteria("Subjects", JoinType.Join)
                                .Add(Resitctions.Eq(Projections.ID, subjectID))
                                .List<Product>();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/401674

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档