有人可以解释一下什么是基于 NHibernate SubQueryExpression 的查询。非常欢迎任何带有具体示例的链接。
谢谢
更新:假设我有一个名为 Beach 的实体。那个海滩可以有很多图像。我想选择海滩实体和它;来自图像集合的第一张图像。我想只携带那个选定的图像对象,或者如果我只选择第二个对象来只携带那个对象。
我不想像 Images.First() 这样访问,因为这将初始化所有集合,如果您需要更多信息,请询问。
有人可以解释一下什么是基于 NHibernate SubQueryExpression 的查询。非常欢迎任何带有具体示例的链接。
谢谢
更新:假设我有一个名为 Beach 的实体。那个海滩可以有很多图像。我想选择海滩实体和它;来自图像集合的第一张图像。我想只携带那个选定的图像对象,或者如果我只选择第二个对象来只携带那个对象。
我不想像 Images.First() 这样访问,因为这将初始化所有集合,如果您需要更多信息,请询问。
var query = session.QueryOver(() => vehicleAlias)
.Left.JoinAlias(() => vehicleAlias.VehicleRegistrations, () => vehicleRegistrationAlias)
.WithSubquery.WhereProperty(() => vehicleRegistrationAlias.RegistrationExpiryDate).Eq(
QueryOver.Of(() => vehicleRegistrationAlias2)
.Where(() => vehicleRegistrationAlias2.Vehicle.Id == vehicleAlias.Id)
.Select(Projections.Max<VehicleRegistration>(ps => ps.RegistrationExpiryDate)));
query.Left.JoinAlias(() => vehicleRegistrationAlias.VehicleRegistrants, () => vehicleRegistrantAlias)
.Where(() => vehicleRegistrantAlias.Client.Id == clientId);
这是我刚刚为我的工作写的一个子查询,我花了一些时间来写。我真的不知道您具体要问什么,但这里有一个示例。如果您对此有任何疑问,请告诉我。
.Select(Projections.Max(ps => ps.RegistrationExpiryDate))) 这一行完成了子查询中的所有工作。它选择最近的车辆登记。车辆登记别名 2 是作为子查询查询的对象。
因此,这将仅撤回车辆的当前车辆登记。一辆车可能有许多车辆登记。它的 .Select 语句可以修改为 .OrderById.Desc.SelectTop(1) 或类似的东西。
我希望这个编辑有帮助。