使用 QueryOver 在相关实体中按属性进行流畅的 NHibernate 排序

发布于 2024-11-04 18:51:39 字数 1210 浏览 0 评论 0原文

我的数据库中有项目和项目组表:

CREATE TABLE [items](
    [item_id] [int] IDENTITY(1,1) NOT NULL,
    [item_name] [varchar](50) NOT NULL,
    [group_id] [int] NOT NULL   
)

CREATE TABLE [itemgroup](
    [group_id] [int] IDENTITY(1,1) NOT NULL,
    [group_name] [varchar](50) NULL 
)

以下是这些实体的映射类:

public class ItemMap : ClassMap<Item>
{
    public ItemMap()
    {
        Table("items");
        Id(x => x.Id).Column("item_id");
        Map(x => x.Name).Column("item_name");
        References(x => x.ItemGroup).Column("group_id").Fetch.Join();            
    }
}
public class ItemGroupMap : ClassMap<ItemGroup>
{
    public ItemGroupMap()
    {
        Table("itemgroup");
        Id(x => x.Id).Column("group_id");
        Map(x => x.Name).Column("group_name");
    }
}

如何使用 QueryOver 从数据库中获取按组名称排序的所有项目?

我知道如何使用 Criteria 来完成它(使用别名)。

var criteria = Session.CreateCriteria<Item>()
                      .CreateAlias("ItemGroup", "group")
                      .AddOrder(Order.Asc("group.Name"));

我尝试创建 ItemGroup 别名并将其与 QueryOver 一起使用,但我的结果是按项目名称而不是按项目组名称排序。

I have items and itemgroup tables in my database:

CREATE TABLE [items](
    [item_id] [int] IDENTITY(1,1) NOT NULL,
    [item_name] [varchar](50) NOT NULL,
    [group_id] [int] NOT NULL   
)

CREATE TABLE [itemgroup](
    [group_id] [int] IDENTITY(1,1) NOT NULL,
    [group_name] [varchar](50) NULL 
)

and here are mapping classes for these entities:

public class ItemMap : ClassMap<Item>
{
    public ItemMap()
    {
        Table("items");
        Id(x => x.Id).Column("item_id");
        Map(x => x.Name).Column("item_name");
        References(x => x.ItemGroup).Column("group_id").Fetch.Join();            
    }
}
public class ItemGroupMap : ClassMap<ItemGroup>
{
    public ItemGroupMap()
    {
        Table("itemgroup");
        Id(x => x.Id).Column("group_id");
        Map(x => x.Name).Column("group_name");
    }
}

How can I get all items from the database ordered by group name using QueryOver?

I know how to accomplish it using Criteria (using alias).

var criteria = Session.CreateCriteria<Item>()
                      .CreateAlias("ItemGroup", "group")
                      .AddOrder(Order.Asc("group.Name"));

I tried to create ItemGroup alias and use it with QueryOver, but my result was sorted by item name not by itemgroup name.

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

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

发布评论

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

评论(1

御守 2024-11-11 18:51:39

它看起来像这样:

Item itemAlias = null;
ItemGroup itemGroupAlias = null; 

session.QueryOver<Item>(() => itemAlias)
    .JoinAlias(() => itemAlias.ItemGroup, () => itemGroupAlias)
    .OrderBy(() => itemGroupAlias.Name).Asc;

It would look something like this:

Item itemAlias = null;
ItemGroup itemGroupAlias = null; 

session.QueryOver<Item>(() => itemAlias)
    .JoinAlias(() => itemAlias.ItemGroup, () => itemGroupAlias)
    .OrderBy(() => itemGroupAlias.Name).Asc;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文