mirror of
				https://github.com/nsnail/FreeSql.git
				synced 2025-11-04 01:05:27 +08:00 
			
		
		
		
	- 优化 GroupBy 聚合函数 Count(bool) 解析成 sum(case when);#1841
This commit is contained in:
		@@ -620,6 +620,17 @@ namespace base_entity
 | 
			
		||||
            #endregion
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
            var sqlc001 = fsql.Select<User1>()
 | 
			
		||||
                .GroupBy(a => a.GroupId)
 | 
			
		||||
                .ToSql(g => new
 | 
			
		||||
                {
 | 
			
		||||
                    cou1 = g.Count(),
 | 
			
		||||
                    cou2 = g.Count(g.Value.Nickname),
 | 
			
		||||
                    cou3 = g.Count(g.Value.Nickname == "xx"),
 | 
			
		||||
                    cou4 = g.Count(g.Value.Sort > 50),
 | 
			
		||||
                    cou5 = g.Count(g.Value.Sort > 50 || g.Value.Username == "xx"),
 | 
			
		||||
                });
 | 
			
		||||
 | 
			
		||||
            fsql.Select<Account>().As("aaa").Where(p => p.ID == 1).AsQueryable().Distinct().Select(p => new { p.Name, p.ID }).Count();
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1104,93 +1104,6 @@
 | 
			
		||||
            </summary>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="T:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder">
 | 
			
		||||
            <summary>
 | 
			
		||||
            动态创建实体类型
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.#ctor(IFreeSql,System.String,System.Attribute[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            配置Class
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="className">类名</param>
 | 
			
		||||
            <param name="attributes">类标记的特性[Table(Name = "xxx")] [Index(xxxx)]</param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="P:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.TypeBuilder">
 | 
			
		||||
            <summary>
 | 
			
		||||
            获取类型构建器,可作为要构建的Type来引用
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.Property(System.String,System.Type,System.Attribute[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            配置属性
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="propertyName">属性名称</param>
 | 
			
		||||
            <param name="propertyType">属性类型</param>
 | 
			
		||||
            <param name="attributes">属性标记的特性-支持多个</param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.Property(System.String,System.Type,System.Boolean,System.Attribute[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            配置属性
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="propertyName">属性名称</param>
 | 
			
		||||
            <param name="propertyType">属性类型</param>
 | 
			
		||||
            <param name="isOverride">该属性是否重写父类属性</param>
 | 
			
		||||
            <param name="attributes">属性标记的特性-支持多个</param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.Property(System.String,System.Type,System.Boolean,System.Object,System.Attribute[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            配置属性
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="propertyName">属性名称</param>
 | 
			
		||||
            <param name="propertyType">属性类型</param>
 | 
			
		||||
            <param name="isOverride">该属性是否重写父类属性</param>
 | 
			
		||||
            <param name="defaultValue">属性默认值</param>
 | 
			
		||||
            <param name="attributes">属性标记的特性-支持多个</param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.Extend(System.Type)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            配置父类
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="superClass">父类类型</param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.OverrideProperty(System.Reflection.Emit.TypeBuilder@,System.Reflection.Emit.MethodBuilder,FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.PropertyMethodEnum,System.String)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            Override属性
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="typeBuilder"></param>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.Build">
 | 
			
		||||
            <summary>
 | 
			
		||||
            Emit动态创建出Class - Type
 | 
			
		||||
            </summary>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.BuildJustType">
 | 
			
		||||
            <summary>
 | 
			
		||||
            Emit动态创建出Class - Type,不附带获取TableInfo
 | 
			
		||||
            </summary>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.FirstCharToLower(System.String)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            首字母小写
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="input"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.DynamicEntity.DynamicCompileBuilder.FirstCharToUpper(System.String)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            首字母大写
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="input"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSql.Extensions.EntityUtil.EntityUtilExtensions.GetEntityKeyString(IFreeSql,System.Type,System.Object,System.Boolean,System.String)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            获取实体的主键值,以 "*|_,[,_|*" 分割,当任意一个主键属性无值时,返回 ""
 | 
			
		||||
@@ -5913,28 +5826,6 @@
 | 
			
		||||
            请使用 fsql.InsertDict(dict) 方法插入字典数据
 | 
			
		||||
            </summary>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSqlGlobalDynamicEntityExtensions.DynamicEntity(FreeSql.ICodeFirst,System.String,System.Attribute[])">
 | 
			
		||||
            <summary>
 | 
			
		||||
            动态构建Class Type
 | 
			
		||||
            </summary>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSqlGlobalDynamicEntityExtensions.CreateInstance(FreeSql.Internal.Model.TableInfo,System.Collections.Generic.Dictionary{System.String,System.Object})">
 | 
			
		||||
            <summary>
 | 
			
		||||
            根据字典,创建 table 对应的实体对象
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="table"></param>
 | 
			
		||||
            <param name="dict"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSqlGlobalDynamicEntityExtensions.CreateDictionary(FreeSql.Internal.Model.TableInfo,System.Object)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            根据实体对象,创建 table 对应的字典
 | 
			
		||||
            </summary>
 | 
			
		||||
            <param name="table"></param>
 | 
			
		||||
            <param name="instance"></param>
 | 
			
		||||
            <returns></returns>
 | 
			
		||||
        </member>
 | 
			
		||||
        <member name="M:FreeSqlGlobalExpressionCallExtensions.Between(System.DateTime,System.DateTime,System.DateTime)">
 | 
			
		||||
            <summary>
 | 
			
		||||
            C#: that >= between && that <= and<para></para>
 | 
			
		||||
 
 | 
			
		||||
@@ -1194,7 +1194,10 @@ namespace FreeSql.Internal
 | 
			
		||||
                    {
 | 
			
		||||
                        switch (exp3.Method.Name)
 | 
			
		||||
                        {
 | 
			
		||||
                            case "Count": return exp3.Arguments.Count == 0 ? "count(1)" : $"count({ExpressionLambdaToSql(exp3.Arguments[0], tsc)})";
 | 
			
		||||
                            case "Count":
 | 
			
		||||
                                if (exp3.Arguments.Count == 0) return "count(1)";
 | 
			
		||||
                                if (exp3.Arguments[0].Type == typeof(bool)) return $"sum({_common.IIF(ExpressionLambdaToSql(exp3.Arguments[0], tsc), "1", "0")})";
 | 
			
		||||
                                return $"count({ExpressionLambdaToSql(exp3.Arguments[0], tsc)})";
 | 
			
		||||
                            case "Sum": return $"sum({ExpressionLambdaToSql(exp3.Arguments[0], tsc)})";
 | 
			
		||||
                            case "Avg": return $"avg({ExpressionLambdaToSql(exp3.Arguments[0], tsc)})";
 | 
			
		||||
                            case "Max": return $"max({ExpressionLambdaToSql(exp3.Arguments[0], tsc)})";
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user