我正在尝试使用NHibernate创建与下面类似的代码。我已经使用fluent完成了所有的映射,我可以很好地完成基本的查询,但是我不知道怎么做。
-**Product Table**
Reference
Title
Subjects (Many to Many relationship)
Price
-**Subject table**
SubjectID
Name
-**SubjectToProductMapping Table**
Reference
SubjectID
现在我需要这样做:
SELECT *
FROM Product
WHERE Reference IN
(Select Reference FROM SubjectToProductMapping WHERE SubjectID = @SubjectID)
记住,Product表已经为post大大简化了,我更喜欢使用IN语句来保持查询的其余部分更简单。理想情况下,我希望使用条件创建查询,因为我将使用条件来对结果进行分页。
提前感谢
发布于 2009-01-02 21:46:28
如果连接就足够了,为什么还要使用in呢?如果您的Products类有一个映射的主题集合,那么您可以只使用以下条件
IList<Product> results = session.CreateCriteria(typeof(Product))
.CreateCriteria("Subjects", JoinType.Join)
.Add(Resitctions.Eq(Projections.ID, subjectID))
.List<Product>();
https://stackoverflow.com/questions/401674
复制相似问题