Query_InnerJoin_ByJoin_Test.cs 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. using System.Data;
  2. using Microsoft.VisualStudio.TestTools.UnitTesting;
  3. namespace Vitorm.MsTest.CommonTest
  4. {
  5. [TestClass]
  6. public class Query_InnerJoin_ByJoin_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 sql = query.ToExecuteString();
  21. var userList = query.ToList();
  22. Assert.AreEqual(1, userList.Count);
  23. Assert.AreEqual(3, userList.First().user.id);
  24. Assert.AreEqual(5, userList.First().father.id);
  25. }
  26. // Lambda Expression
  27. {
  28. var query =
  29. userQuery.SelectMany(
  30. user => userQuery.Where(father => user.fatherId == father.id)
  31. , (user, father) => new { user, father }
  32. )
  33. .Where(row => row.user.id > 2)
  34. .Select(row => new { row.user, row.father });
  35. var sql = query.ToExecuteString();
  36. var userList = query.ToList();
  37. Assert.AreEqual(1, userList.Count);
  38. Assert.AreEqual(3, userList.First().user.id);
  39. Assert.AreEqual(5, userList.First().father.id);
  40. }
  41. }
  42. [TestMethod]
  43. public void Test_InnerJoin_Complex()
  44. {
  45. using var dbContext = DataSource.CreateDbContext();
  46. var userQuery = dbContext.Query<User>();
  47. // Linq Expression
  48. {
  49. var query =
  50. from user in userQuery
  51. join father in userQuery on user.fatherId equals father.id
  52. join mother in userQuery on user.motherId equals mother.id
  53. where user.id > 1
  54. orderby father.id descending
  55. select new
  56. {
  57. user,
  58. father,
  59. mother,
  60. testId = user.id + 100,
  61. hasFather = father != null ? true : false
  62. };
  63. query = query.Skip(1).Take(1);
  64. var sql = query.ToExecuteString();
  65. var userList = query.ToList();
  66. Assert.AreEqual(1, userList.Count);
  67. var first = userList.First();
  68. Assert.AreEqual(2, first.user.id);
  69. Assert.AreEqual(4, first.father.id);
  70. Assert.AreEqual(6, first.mother.id);
  71. Assert.AreEqual(102, first.testId);
  72. Assert.AreEqual(true, first.hasFather);
  73. }
  74. // Lambda Expression
  75. {
  76. var query =
  77. userQuery.Join(
  78. userQuery
  79. , user => user.fatherId
  80. , father => father.id
  81. , (user, father) => new { user, father }
  82. ).Join(
  83. userQuery
  84. , row => row.user.motherId
  85. , mother => mother.id
  86. , (row, mother) => new { row, mother }
  87. )
  88. .Where(row2 => row2.row.user.id > 1)
  89. .OrderByDescending(row2 => row2.row.father.id)
  90. .Select(row2 =>
  91. new
  92. {
  93. row2.row.user,
  94. row2.row.father,
  95. row2.mother,
  96. testId = row2.row.user.id + 100,
  97. hasFather = row2.row.father != null ? true : false
  98. }
  99. );
  100. query = query.Skip(1).Take(1);
  101. var sql = query.ToExecuteString();
  102. var userList = query.ToList();
  103. Assert.AreEqual(1, userList.Count);
  104. var first = userList.First();
  105. Assert.AreEqual(2, first.user.id);
  106. Assert.AreEqual(4, first.father.id);
  107. Assert.AreEqual(6, first.mother.id);
  108. Assert.AreEqual(102, first.testId);
  109. Assert.AreEqual(true, first.hasFather);
  110. }
  111. }
  112. [TestMethod]
  113. public void Test_InnerJoin_Others()
  114. {
  115. using var dbContext = DataSource.CreateDbContext();
  116. var userQuery = dbContext.Query<User>();
  117. // simple
  118. {
  119. var query =
  120. userQuery.Join(
  121. userQuery
  122. , user => user.fatherId
  123. , father => father.id
  124. , (user, father) => new { user, father }
  125. );
  126. var sql = query.ToExecuteString();
  127. var userList = query.ToList();
  128. Assert.AreEqual(3, userList.Count);
  129. Assert.AreEqual(1, userList.First().user.id);
  130. }
  131. // where
  132. {
  133. var query =
  134. userQuery.Join(
  135. userQuery
  136. , user => user.fatherId
  137. , father => father.id
  138. , (user, father) => new { user, father }
  139. ).Where(row => row.user.id > 2);
  140. var sql = query.ToExecuteString();
  141. var userList = query.ToList();
  142. Assert.AreEqual(1, userList.Count);
  143. Assert.AreEqual(3, userList.First().user.id);
  144. }
  145. // select
  146. {
  147. var query =
  148. userQuery.Join(
  149. userQuery
  150. , user => user.fatherId
  151. , father => father.id
  152. , (user, father) => new { user, father }
  153. ).Where(row => row.user.id > 2)
  154. .Select(row => new { userId = row.user.id, fatherId = row.father.id });
  155. var sql = query.ToExecuteString();
  156. var userList = query.ToList();
  157. Assert.AreEqual(1, userList.Count);
  158. Assert.AreEqual(3, userList.First().userId);
  159. Assert.AreEqual(5, userList.First().fatherId);
  160. }
  161. // full feature
  162. {
  163. var query =
  164. from user in userQuery
  165. join father in userQuery on user.fatherId equals father.id
  166. where user.id > 1
  167. orderby user.id descending
  168. select new { user, father };
  169. query = query.Skip(1).Take(1);
  170. var sql = query.ToExecuteString();
  171. var userList = query.ToList();
  172. Assert.AreEqual(1, userList.Count);
  173. Assert.AreEqual(2, userList.First().user.id);
  174. }
  175. }
  176. }
  177. }