Query_InnerJoin_BySelectMany_Test.cs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. using System.Data;
  2. using Microsoft.VisualStudio.TestTools.UnitTesting;
  3. namespace Vitorm.MsTest.CommonTest
  4. {
  5. [TestClass]
  6. public class Query_InnerJoin_BySelectMany_Test
  7. {
  8. [TestMethod]
  9. public void Test_InnerJoin_Demo()
  10. {
  11. using var dbContext = DataSource.CreateDbContext();
  12. var userQuery = dbContext.Query<User>();
  13. // Linq Expression
  14. {
  15. var query =
  16. from user in userQuery
  17. from father in userQuery.Where(father => user.fatherId == father.id)
  18. where user.id > 2
  19. select new { user, father };
  20. var userList = query.ToList();
  21. Assert.AreEqual(1, userList.Count);
  22. Assert.AreEqual(3, userList.First().user.id);
  23. Assert.AreEqual(5, userList.First().father.id);
  24. }
  25. // Lambda Expression
  26. {
  27. var query =
  28. userQuery.SelectMany(
  29. user => userQuery.Where(father => user.fatherId == father.id)
  30. , (user, father) => new { user, father }
  31. )
  32. .Where(row => row.user.id > 2)
  33. .Select(row => new { row.user, row.father });
  34. var userList = query.ToList();
  35. Assert.AreEqual(1, userList.Count);
  36. Assert.AreEqual(3, userList.First().user.id);
  37. Assert.AreEqual(5, userList.First().father.id);
  38. }
  39. }
  40. [TestMethod]
  41. public void Test_InnerJoin_Complex()
  42. {
  43. using var dbContext = DataSource.CreateDbContext();
  44. var userQuery = dbContext.Query<User>();
  45. // Linq Expression
  46. {
  47. var query =
  48. from user in userQuery
  49. from father in userQuery.Where(father => user.fatherId == father.id)
  50. from mother in userQuery.Where(mother => user.motherId == mother.id)
  51. where user.id > 1
  52. orderby father.id descending
  53. select new
  54. {
  55. user,
  56. father,
  57. mother,
  58. testId = user.id + 100,
  59. hasFather = father != null ? true : false
  60. };
  61. query = query.Skip(1).Take(1);
  62. var userList = query.ToList();
  63. Assert.AreEqual(1, userList.Count);
  64. var first = userList.First();
  65. Assert.AreEqual(2, first.user.id);
  66. Assert.AreEqual(4, first.father.id);
  67. Assert.AreEqual(6, first.mother.id);
  68. Assert.AreEqual(102, first.testId);
  69. Assert.AreEqual(true, first.hasFather);
  70. }
  71. // Lambda Expression
  72. {
  73. var query =
  74. userQuery.SelectMany(
  75. user => userQuery.Where(father => user.fatherId == father.id)
  76. , (user, father) => new { user, father }
  77. ).SelectMany(
  78. row => userQuery.Where(mother => row.user.motherId == mother.id)
  79. , (row, mother) => new { row, mother }
  80. )
  81. .Where(row2 => row2.row.user.id > 1)
  82. .OrderByDescending(row2 => row2.row.father.id)
  83. .Select(row2 =>
  84. new
  85. {
  86. row2.row.user,
  87. row2.row.father,
  88. row2.mother,
  89. testId = row2.row.user.id + 100,
  90. hasFather = row2.row.father != null ? true : false
  91. }
  92. );
  93. query = query.Skip(1).Take(1);
  94. var userList = query.ToList();
  95. Assert.AreEqual(1, userList.Count);
  96. var first = userList.First();
  97. Assert.AreEqual(2, first.user.id);
  98. Assert.AreEqual(4, first.father.id);
  99. Assert.AreEqual(6, first.mother.id);
  100. Assert.AreEqual(102, first.testId);
  101. Assert.AreEqual(true, first.hasFather);
  102. }
  103. }
  104. [TestMethod]
  105. public void Test_MultipleSelect()
  106. {
  107. using var dbContext = DataSource.CreateDbContext();
  108. var userQuery = dbContext.Query<User>();
  109. {
  110. var query = from user in userQuery
  111. from father in userQuery.Where(father => user.fatherId == father.id)
  112. from mother in userQuery.Where(mother => user.motherId == mother.id)
  113. orderby user.id
  114. select new
  115. {
  116. uniqueId = user.id + "_" + father.id + "_" + mother.id,
  117. uniqueId1 = user.id + "_" + user.fatherId + "_" + user.motherId,
  118. user,
  119. user2 = user,
  120. user3 = user,
  121. father,
  122. hasFather = user.fatherId != null ? true : false,
  123. fatherName = father.name,
  124. mother
  125. };
  126. var userList = query.ToList();
  127. Assert.AreEqual(3, userList.Count);
  128. Assert.AreEqual(1, userList.First().user.id);
  129. Assert.AreEqual(3, userList.Last().user.id);
  130. Assert.AreEqual(5, userList.Last().father?.id);
  131. }
  132. {
  133. var query = from user in userQuery
  134. from father in userQuery.Where(father => user.fatherId == father.id)
  135. from mother in userQuery.Where(mother => user.motherId == mother.id)
  136. where user.id > 1
  137. orderby user.id
  138. select new
  139. {
  140. user,
  141. father,
  142. userId = user.id + 100,
  143. hasFather = user.fatherId != null ? true : false,
  144. hasFather2 = father != null,
  145. fatherName = father.name,
  146. motherName = mother.name,
  147. };
  148. var userList = query.ToList();
  149. Assert.AreEqual(2, userList.Count);
  150. Assert.AreEqual(4, userList.First().father?.id);
  151. Assert.AreEqual(5, userList.Last().father?.id);
  152. }
  153. }
  154. }
  155. }