|
1 | 1 | using System;
|
2 | 2 | using System.Linq;
|
3 | 3 | using System.Linq.Expressions;
|
| 4 | +using NHibernate.Dialect; |
4 | 5 | using NHibernate.DomainModel.Northwind.Entities;
|
| 6 | +using NHibernate.Linq; |
5 | 7 | using NUnit.Framework;
|
6 | 8 |
|
7 | 9 | namespace NHibernate.Test.Linq
|
@@ -509,6 +511,74 @@ where subquery.Any(x => x.OrderId == order.OrderId)
|
509 | 511 | Assert.That(query.Count, Is.EqualTo(61));
|
510 | 512 | }
|
511 | 513 |
|
| 514 | + [Test(Description = "GH2479")] |
| 515 | + public void OrdersWithSubquery9() |
| 516 | + { |
| 517 | + if (Dialect is MySQLDialect) |
| 518 | + Assert.Ignore("MySQL does not support LIMIT in subqueries."); |
| 519 | + |
| 520 | + var ordersQuery = db.Orders |
| 521 | + .Where(x => x.Employee.EmployeeId > 5) |
| 522 | + .OrderBy(x => x.OrderId) |
| 523 | + .Take(2); |
| 524 | + |
| 525 | + var orderLinesFuture = db.OrderLines |
| 526 | + .Where(x => ordersQuery.Any(o => o == x.Order)) |
| 527 | + .OrderBy(x => x.Id) |
| 528 | + .ToFuture(); |
| 529 | + |
| 530 | + var orders = ordersQuery.ToFuture().ToList(); |
| 531 | + var orderLines = orderLinesFuture.ToList(); |
| 532 | + |
| 533 | + Assert.That(orders.Count, Is.EqualTo(2), nameof(orders)); |
| 534 | + Assert.That(orderLines.Count, Is.EqualTo(6), nameof(orderLines)); |
| 535 | + } |
| 536 | + |
| 537 | + [Test(Description = "GH2479")] |
| 538 | + public void OrdersWithSubquery10() |
| 539 | + { |
| 540 | + if (Dialect is MySQLDialect) |
| 541 | + Assert.Ignore("MySQL does not support LIMIT in subqueries."); |
| 542 | + |
| 543 | + var ordersQuery = db.Orders |
| 544 | + .Where(x => x.Employee.EmployeeId > 5) |
| 545 | + .OrderBy(x => x.OrderId) |
| 546 | + .Take(2); |
| 547 | + |
| 548 | + var productsQuery = ordersQuery.SelectMany(x => x.OrderLines).Select(x => x.Product); |
| 549 | + var productsFuture = db.Products |
| 550 | + .Where(x => productsQuery.Contains(x)) |
| 551 | + .OrderBy(x => x.ProductId) |
| 552 | + .ToFuture(); |
| 553 | + |
| 554 | + var orders = ordersQuery.ToFuture().ToList(); |
| 555 | + var products = productsFuture.ToList(); |
| 556 | + |
| 557 | + Assert.That(orders.Count, Is.EqualTo(2), nameof(orders)); |
| 558 | + Assert.That(products.Count, Is.EqualTo(6), nameof(products)); |
| 559 | + } |
| 560 | + |
| 561 | + [Test(Description = "GH2479")] |
| 562 | + public void OrdersWithSubquery11() |
| 563 | + { |
| 564 | + if (Dialect is MySQLDialect) |
| 565 | + Assert.Ignore("MySQL does not support LIMIT in subqueries."); |
| 566 | + if (Dialect is MsSqlCeDialect) |
| 567 | + Assert.Ignore("MS SQL CE does not support sorting on a subquery."); |
| 568 | + |
| 569 | + var ordersQuery = db.Orders |
| 570 | + .OrderByDescending(x => x.OrderLines.Count).ThenBy(x => x.OrderId) |
| 571 | + .Take(2); |
| 572 | + |
| 573 | + var orderLineQuery = ordersQuery.SelectMany(x => x.OrderLines); |
| 574 | + var productsNotInLargestOrders = db.Products |
| 575 | + .Where(x => orderLineQuery.All(p => p.Product != x)) |
| 576 | + .OrderBy(x => x.ProductId) |
| 577 | + .ToList(); |
| 578 | + |
| 579 | + Assert.That(productsNotInLargestOrders.Count, Is.EqualTo(49), nameof(productsNotInLargestOrders)); |
| 580 | + } |
| 581 | + |
512 | 582 | [Test(Description = "NH-2654")]
|
513 | 583 | public void CategoriesWithDiscountedProducts()
|
514 | 584 | {
|
|
0 commit comments