mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-25 18:29:13 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			122 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Linq;
 | |
| using System.Text;
 | |
| using System.Text.RegularExpressions;
 | |
| 
 | |
| namespace SqlSugar.HG
 | |
| {
 | |
|     public partial class HGQueryBuilder : QueryBuilder
 | |
|     {
 | |
|         #region Sql Template
 | |
|         public override string PageTempalte
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 /*
 | |
|                  SELECT * FROM TABLE WHERE CONDITION ORDER BY ID DESC LIMIT 10 offset 0
 | |
|                  */
 | |
|                 var template = "SELECT {0} FROM {1} {2} {3} {4} LIMIT {6} offset {5}";
 | |
|                 return template;
 | |
|             }
 | |
|         }
 | |
|         public override string DefaultOrderByTemplate
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return "ORDER BY NOW() ";
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         #endregion
 | |
| 
 | |
|         #region Common Methods
 | |
|         public override string GetTableNameString
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 if (this.TableShortName != null&&this.Context.CurrentConnectionConfig?.MoreSettings?.PgSqlIsAutoToLower==false) 
 | |
|                 {
 | |
|                     this.TableShortName = Builder.GetTranslationColumnName(this.TableShortName);
 | |
|                 }
 | |
|                 return base.GetTableNameString;
 | |
|             }
 | |
|         }
 | |
|         public override bool IsComplexModel(string sql)
 | |
|         {
 | |
|             return Regex.IsMatch(sql, @"AS ""\w+\.\w+""")|| Regex.IsMatch(sql, @"AS ""\w+\.\w+\.\w+""");
 | |
|         }
 | |
|         public override string ToSqlString()
 | |
|         {
 | |
|             base.AppendFilter();
 | |
|             string oldOrderValue = this.OrderByValue;
 | |
|             string result = null;
 | |
|             sql = new StringBuilder();
 | |
|             sql.AppendFormat(SqlTemplate, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString);
 | |
|             if (IsCount) { return sql.ToString(); }
 | |
|             if (Skip != null && Take == null)
 | |
|             {
 | |
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0];
 | |
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, (Skip != null || Take != null) ? null : GetOrderByString, Skip.ObjToInt(), long.MaxValue);
 | |
|             }
 | |
|             else if (Skip == null && Take != null)
 | |
|             {
 | |
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0];
 | |
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, 0, Take.ObjToInt());
 | |
|             }
 | |
|             else if (Skip != null && Take != null)
 | |
|             {
 | |
|                 if (this.OrderByValue == "ORDER BY ") this.OrderByValue += GetSelectValue.Split(',')[0];
 | |
|                 result = string.Format(PageTempalte, GetSelectValue, GetTableNameString, GetWhereValueString, GetGroupByString + HavingInfos, GetOrderByString, Skip.ObjToInt() > 0 ? Skip.ObjToInt() : 0, Take);
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 result = sql.ToString();
 | |
|             }
 | |
|             this.OrderByValue = oldOrderValue;
 | |
|             result = GetSqlQuerySql(result);
 | |
|             if (result.IndexOf("-- No table") > 0)
 | |
|             {
 | |
|                 return "-- No table";
 | |
|             }
 | |
|             if (TranLock != null)
 | |
|             {
 | |
|                 result = result + TranLock;
 | |
|             }
 | |
|             return result;
 | |
|         }
 | |
| 
 | |
|         #endregion
 | |
| 
 | |
|         #region Get SQL Partial
 | |
|         public override string GetSelectValue
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 string result = string.Empty;
 | |
|                 if (this.SelectValue == null || this.SelectValue is string)
 | |
|                 {
 | |
|                     result = GetSelectValueByString();
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     result = GetSelectValueByExpression();
 | |
|                 }
 | |
|                 if (this.SelectType == ResolveExpressType.SelectMultiple)
 | |
|                 {
 | |
|                     this.SelectCacheKey = this.SelectCacheKey + string.Join("-", this.JoinQueryInfos.Select(it => it.TableName));
 | |
|                 }
 | |
|                 if (IsDistinct) 
 | |
|                 {
 | |
|                     result = "distinct "+result;
 | |
|                 }
 | |
|                 if (this.SubToListParameters != null && this.SubToListParameters.Any())
 | |
|                 {
 | |
|                     result = SubToListMethod(result);
 | |
|                 }
 | |
|                 return result;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         #endregion
 | |
|     }
 | |
| }
 | 
