ResultElement.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. using Ant.Common;
  2. using Ant.DbExpressions;
  3. using Ant.Utility;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Linq;
  7. using System.Reflection;
  8. using System.Text;
  9. namespace Ant.Query
  10. {
  11. public class ResultElement
  12. {
  13. public ResultElement()
  14. {
  15. this.Orderings = new List<DbOrdering>();
  16. this.GroupSegments = new List<DbExpression>();
  17. }
  18. public IMappingObjectExpression MappingObjectExpression { get; set; }
  19. public bool OrderingsComeFromSubQuery { get; set; }
  20. /// <summary>
  21. /// 排序列表
  22. /// </summary>
  23. public List<DbOrdering> Orderings { get; private set; }
  24. /// <summary>
  25. ///
  26. /// </summary>
  27. public List<DbExpression> GroupSegments { get; private set; }
  28. /// <summary>
  29. /// 如 takequery 了以后,则 table 的 Expression 类似 (select T.Id.. from User as T),Alias 则为新生成的
  30. /// </summary>
  31. public DbFromTableExpression FromTable { get; set; }
  32. /// <summary>
  33. /// 查询条件
  34. /// </summary>
  35. public DbExpression Condition { get; set; }
  36. /// <summary>
  37. ///
  38. /// </summary>
  39. public DbExpression HavingCondition { get; set; }
  40. public void AppendCondition(DbExpression condition)
  41. {
  42. if (this.Condition == null)
  43. this.Condition = condition;
  44. else
  45. this.Condition = new DbAndAlsoExpression(this.Condition, condition);
  46. }
  47. public void AppendHavingCondition(DbExpression condition)
  48. {
  49. if (this.HavingCondition == null)
  50. this.HavingCondition = condition;
  51. else
  52. this.HavingCondition = new DbAndAlsoExpression(this.HavingCondition, condition);
  53. }
  54. public string GenerateUniqueTableAlias(string prefix = UtilConstants.DefaultTableAlias)
  55. {
  56. if (this.FromTable == null)
  57. return prefix;
  58. string alias = prefix;
  59. int i = 0;
  60. DbFromTableExpression fromTable = this.FromTable;
  61. while (ExistTableAlias(fromTable, alias))
  62. {
  63. alias = prefix + i.ToString();
  64. i++;
  65. }
  66. return alias;
  67. }
  68. static bool ExistTableAlias(DbMainTableExpression mainTable, string alias)
  69. {
  70. if (string.Equals(mainTable.Table.Alias, alias, StringComparison.OrdinalIgnoreCase))
  71. return true;
  72. foreach (DbJoinTableExpression joinTable in mainTable.JoinTables)
  73. {
  74. if (ExistTableAlias(joinTable, alias))
  75. return true;
  76. }
  77. return false;
  78. }
  79. }
  80. }