我目前正在写一个非常基本的在线论坛,我想检索一个带有分页帖子的子集的线程。所以我的映射是:
<class name="Thread" table="ForumThreads">
<id name="Id">
<generator class="identity"></generator>
</id>
<property name="Title"></property>
<bag name="Posts">
<key column="ThreadID"></key>
<one-to-many class="Post"/>
</bag>
</class>
<class name="Post" table="ForumPosts">
<id name="Id">
<generator class="identity"></generator>
</id>
<property name="Content"></property>
<many-to-one name="Thread"
class="Thread"
column="ThreadID">
</many-to-one>
</class>我想做这样的事情:
public class Thread
{
public virtual int Id { get; set; }
public virtual string Title { get; set; }
public virtual IEnumerable<Post> Posts { get; set; }
}
public class Post
{
public virtual int Id { get; set; }
public virtual Thread Thread { get; set; }
public virtual string Content { get; set; }
}
public Thread GetThread(int threadId, int page, int pageSize, out int count)
{
var session = SessionFactory.CurrentSession;
// Query to get the thread with a child collection of paged posts.
return thread;
}有没有可能用一个查询就能做到这一点,或者我必须将它一分为二?
谢谢
发布于 2012-04-03 22:35:53
var threadId = ...
session.QueryOver<Thread>
.Where(thread => thread.Id == threadId)
.Fetch(thread => thread.Posts).Eager
.Take(pageSize)
.Skip(page)
.TransformUsing(Transformers.DistinctRootEntity)
.List<Thread>();发布于 2012-04-04 20:41:27
如果您正在考虑进行数据库级别的分页,那么方法应该是这样的:
公用分发列表GetThreadPosts(int threadId,int page,int pageSize,out int count) { var session = SessionFactory.CurrentSession;Thread pageSize= (Thread )session.Get(typeof(Thread ),threadId);var posts =session.CreateFilter(线程.Posts,"").SetFirstResult((page - 1) * pageSize).SetMaxResults(pageSize).List();return posts;}
https://stackoverflow.com/questions/9994825
复制相似问题