IncludesHelper.cs 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Linq.Expressions;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace SqlSugar
  8. {
  9. public partial class QueryableProvider<T> : QueryableAccessory, ISugarQueryable<T>
  10. {
  11. private void _Includes<T1, TReturn1>(SqlSugarProvider context, params Expression[] expressions)
  12. {
  13. Func<ISugarQueryable<object>,List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x=>x as object).ToList();
  14. var navigat = new NavigatManager<T>();
  15. navigat.SelectR1 = SelectR1;
  16. navigat.Expressions = expressions;
  17. navigat.Context = this.Context;
  18. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  19. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  20. navigat.QueryBuilder = this.QueryBuilder;
  21. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  22. this.QueryBuilder.Includes.Add(navigat);
  23. }
  24. private void _Includes<T1, TReturn1, TReturn2>(SqlSugarProvider context, params Expression[] expressions)
  25. {
  26. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  27. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  28. var navigat = new NavigatManager<T>();
  29. navigat.SelectR1 = SelectR1;
  30. navigat.SelectR2 = SelectR2;
  31. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  32. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  33. navigat.Expressions = expressions;
  34. navigat.Context = this.Context;
  35. navigat.QueryBuilder = this.QueryBuilder;
  36. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  37. this.QueryBuilder.Includes.Add(navigat);
  38. }
  39. private void _Includes<T1, TReturn1, TReturn2, TReturn3>(SqlSugarProvider context, params Expression[] expressions)
  40. {
  41. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  42. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  43. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  44. var navigat = new NavigatManager<T>();
  45. navigat.SelectR1 = SelectR1;
  46. navigat.SelectR2 = SelectR2;
  47. navigat.SelectR3 = SelectR3;
  48. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  49. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  50. navigat.Expressions = expressions;
  51. navigat.Context = this.Context;
  52. navigat.QueryBuilder = this.QueryBuilder;
  53. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  54. this.QueryBuilder.Includes.Add(navigat);
  55. }
  56. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4>(SqlSugarProvider context, params Expression[] expressions)
  57. {
  58. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  59. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  60. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  61. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  62. var navigat = new NavigatManager<T>();
  63. navigat.SelectR1 = SelectR1;
  64. navigat.SelectR2 = SelectR2;
  65. navigat.SelectR3 = SelectR3;
  66. navigat.SelectR4 = SelectR4;
  67. navigat.Expressions = expressions;
  68. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  69. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  70. navigat.Context = this.Context;
  71. navigat.QueryBuilder = this.QueryBuilder;
  72. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  73. this.QueryBuilder.Includes.Add(navigat);
  74. }
  75. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4, TReturn5>(SqlSugarProvider context, params Expression[] expressions)
  76. {
  77. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  78. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  79. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  80. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  81. Func<ISugarQueryable<object>, List<object>> SelectR5 = it => it.Select<TReturn5>().ToList().Select(x => x as object).ToList();
  82. var navigat = new NavigatManager<T>();
  83. navigat.SelectR1 = SelectR1;
  84. navigat.SelectR2 = SelectR2;
  85. navigat.SelectR3 = SelectR3;
  86. navigat.SelectR4 = SelectR4;
  87. navigat.SelectR5 = SelectR5;
  88. navigat.Expressions = expressions;
  89. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  90. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  91. navigat.Context = this.Context;
  92. navigat.QueryBuilder = this.QueryBuilder;
  93. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  94. this.QueryBuilder.Includes.Add(navigat);
  95. }
  96. public NavISugarQueryable<T> AsNavQueryable()
  97. {
  98. return GetNavSugarQueryable();
  99. }
  100. private NavISugarQueryable<T> GetNavSugarQueryable()
  101. {
  102. var result= new NavQueryableProvider<T>();
  103. result.Context = this.Context;
  104. var clone = this.Clone();
  105. result.SqlBuilder = clone.SqlBuilder;
  106. result.QueryBuilder = clone.QueryBuilder;
  107. return result;
  108. }
  109. private ISugarQueryable<T> GetManyQueryable<TReturn1>(Expression<Func<T, TReturn1>> include1)
  110. {
  111. ISugarQueryable<T> result = null;
  112. var isManyMembers = IsMembers(include1);
  113. if (isManyMembers)
  114. {
  115. var array = ExpressionTool.ExtractMemberNames(include1);
  116. if (array.Count > 1)
  117. {
  118. if (array.Count == 2)
  119. {
  120. result = this.IncludesByNameString(array[0], array[1]);
  121. }
  122. else if (array.Count == 3)
  123. {
  124. result = this.IncludesByNameString(array[0], array[1], array[2]);
  125. }
  126. else if (array.Count == 4)
  127. {
  128. result = this.IncludesByNameString(array[0], array[1], array[2], array[3]);
  129. }
  130. else if (array.Count == 5)
  131. {
  132. result = this.IncludesByNameString(array[0], array[1], array[2], array[3], array[4]);
  133. }
  134. else if (array.Count == 6)
  135. {
  136. throw new Exception("Multiple levels of expression exceeded the upper limit");
  137. }
  138. }
  139. }
  140. return result;
  141. }
  142. private static bool IsMembers<TReturn1>(Expression<Func<T, TReturn1>> include1)
  143. {
  144. var isManyMembers = false;
  145. var x = ((include1 as LambdaExpression).Body as MemberExpression)?.Expression;
  146. if (x is MemberExpression)
  147. {
  148. var exp = (x as MemberExpression)?.Expression;
  149. if (exp != null)
  150. {
  151. isManyMembers = true;
  152. }
  153. }
  154. return isManyMembers;
  155. }
  156. }
  157. public partial class NavQueryableProvider<T> : QueryableProvider<T>, NavISugarQueryable<T>
  158. {
  159. private void _Includes<T1, TReturn1>(SqlSugarProvider context, params Expression[] expressions)
  160. {
  161. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  162. var navigat = new NavigatManager<T>();
  163. navigat.SelectR1 = SelectR1;
  164. navigat.Expressions = expressions;
  165. navigat.Context = this.Context;
  166. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  167. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  168. navigat.QueryBuilder = this.QueryBuilder;
  169. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  170. this.QueryBuilder.Includes.Add(navigat);
  171. }
  172. private void _Includes<T1, TReturn1, TReturn2>(SqlSugarProvider context, params Expression[] expressions)
  173. {
  174. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  175. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  176. var navigat = new NavigatManager<T>();
  177. navigat.SelectR1 = SelectR1;
  178. navigat.SelectR2 = SelectR2;
  179. navigat.Expressions = expressions;
  180. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  181. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  182. navigat.Context = this.Context;
  183. navigat.QueryBuilder = this.QueryBuilder;
  184. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  185. this.QueryBuilder.Includes.Add(navigat);
  186. }
  187. private void _Includes<T1, TReturn1, TReturn2, TReturn3>(SqlSugarProvider context, params Expression[] expressions)
  188. {
  189. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  190. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  191. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  192. var navigat = new NavigatManager<T>();
  193. navigat.SelectR1 = SelectR1;
  194. navigat.SelectR2 = SelectR2;
  195. navigat.SelectR3 = SelectR3;
  196. navigat.Expressions = expressions;
  197. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  198. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  199. navigat.Context = this.Context;
  200. navigat.QueryBuilder = this.QueryBuilder;
  201. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  202. this.QueryBuilder.Includes.Add(navigat);
  203. }
  204. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4>(SqlSugarProvider context, params Expression[] expressions)
  205. {
  206. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  207. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  208. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  209. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  210. var navigat = new NavigatManager<T>();
  211. navigat.SelectR1 = SelectR1;
  212. navigat.SelectR2 = SelectR2;
  213. navigat.SelectR3 = SelectR3;
  214. navigat.SelectR4 = SelectR4;
  215. navigat.Expressions = expressions;
  216. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  217. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  218. navigat.Context = this.Context;
  219. navigat.QueryBuilder = this.QueryBuilder;
  220. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  221. this.QueryBuilder.Includes.Add(navigat);
  222. }
  223. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4, TReturn5>(SqlSugarProvider context, params Expression[] expressions)
  224. {
  225. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  226. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  227. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  228. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  229. Func<ISugarQueryable<object>, List<object>> SelectR5 = it => it.Select<TReturn5>().ToList().Select(x => x as object).ToList();
  230. var navigat = new NavigatManager<T>();
  231. navigat.SelectR1 = SelectR1;
  232. navigat.SelectR2 = SelectR2;
  233. navigat.SelectR3 = SelectR3;
  234. navigat.SelectR4 = SelectR4;
  235. navigat.SelectR5 = SelectR5;
  236. navigat.Expressions = expressions;
  237. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  238. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  239. navigat.Context = this.Context;
  240. navigat.QueryBuilder = this.QueryBuilder;
  241. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  242. this.QueryBuilder.Includes.Add(navigat);
  243. }
  244. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4, TReturn5, TReturn6>(SqlSugarProvider context, params Expression[] expressions)
  245. {
  246. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  247. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  248. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  249. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  250. Func<ISugarQueryable<object>, List<object>> SelectR5 = it => it.Select<TReturn5>().ToList().Select(x => x as object).ToList();
  251. Func<ISugarQueryable<object>, List<object>> SelectR6 = it => it.Select<TReturn6>().ToList().Select(x => x as object).ToList();
  252. var navigat = new NavigatManager<T>();
  253. navigat.SelectR1 = SelectR1;
  254. navigat.SelectR2 = SelectR2;
  255. navigat.SelectR3 = SelectR3;
  256. navigat.SelectR4 = SelectR4;
  257. navigat.SelectR5 = SelectR5;
  258. navigat.SelectR6 = SelectR6;
  259. navigat.Expressions = expressions;
  260. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  261. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  262. navigat.Context = this.Context;
  263. navigat.QueryBuilder = this.QueryBuilder;
  264. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  265. this.QueryBuilder.Includes.Add(navigat);
  266. }
  267. private void _Includes<T1, TReturn1, TReturn2, TReturn3, TReturn4, TReturn5, TReturn6, TReturn7>(SqlSugarProvider context, params Expression[] expressions)
  268. {
  269. Func<ISugarQueryable<object>, List<object>> SelectR1 = it => it.Select<TReturn1>().ToList().Select(x => x as object).ToList();
  270. Func<ISugarQueryable<object>, List<object>> SelectR2 = it => it.Select<TReturn2>().ToList().Select(x => x as object).ToList();
  271. Func<ISugarQueryable<object>, List<object>> SelectR3 = it => it.Select<TReturn3>().ToList().Select(x => x as object).ToList();
  272. Func<ISugarQueryable<object>, List<object>> SelectR4 = it => it.Select<TReturn4>().ToList().Select(x => x as object).ToList();
  273. Func<ISugarQueryable<object>, List<object>> SelectR5 = it => it.Select<TReturn5>().ToList().Select(x => x as object).ToList();
  274. Func<ISugarQueryable<object>, List<object>> SelectR6 = it => it.Select<TReturn6>().ToList().Select(x => x as object).ToList();
  275. Func<ISugarQueryable<object>, List<object>> SelectR7 = it => it.Select<TReturn7>().ToList().Select(x => x as object).ToList();
  276. var navigat = new NavigatManager<T>();
  277. navigat.SelectR1 = SelectR1;
  278. navigat.SelectR2 = SelectR2;
  279. navigat.SelectR3 = SelectR3;
  280. navigat.SelectR4 = SelectR4;
  281. navigat.SelectR5 = SelectR5;
  282. navigat.SelectR6 = SelectR6;
  283. navigat.SelectR7 = SelectR7;
  284. navigat.Expressions = expressions;
  285. navigat.QueryBuilder = this.QueryBuilder;
  286. navigat.IsCrossQueryWithAttr = this.QueryBuilder.IsCrossQueryWithAttr;
  287. navigat.CrossQueryItems = this.QueryBuilder.CrossQueryItems;
  288. navigat.Context = this.Context;
  289. if (this.QueryBuilder.Includes == null) this.QueryBuilder.Includes = new List<object>();
  290. this.QueryBuilder.Includes.Add(navigat);
  291. }
  292. }
  293. }