分頁查詢優化

新]根據查詢實體獲取查詢結果[SQL_CALC_FOUND_ROWS;SELECT FOUND_ROWS()一次性取出分頁數據和知足條件的全部數據行]
Select SQL_CALC_FOUND_ROWS 
SELECT FOUND_ROWS() --獲取總行數
/// <summary>
        /// [新]根據查詢實體獲取查詢結果
        /// </summary>
        /// <typeparam name="SearchT">查詢實體類型</typeparam>
        /// <typeparam name="ResultT">響應結果類型</typeparam>
        /// <param name="searchEntity">查詢實體對象</param>
        /// <param name="resultEntity">響應結果對象</param>
        /// <param name="pageIndex">頁索引</param>
        /// <param name="pageSize">頁大小</param>
        /// <param name="rowsCount">返回行總數</param>
        /// <param name="tableName">表名</param>
        /// <param name="orderBy">排序列名[多個請用逗號分開,注意最後一個不要指定排序方式]</param>
        /// <param name="orderByEnum">排序方式</param>
        /// <param name="excludeExpressions">過濾屬性集合</param>
        /// <returns></returns>
        public static List<ResultT> GetListByPageSearchEntityNew<SearchT, ResultT>(SearchT searchEntity, ResultT resultEntity,
            int pageIndex, int pageSize, out int rowsCount, string tableName, string orderBy = "", OrderByEnum orderByEnum = OrderByEnum.Desc,
            params Expression<Func<ResultT, object>>[] excludeExpressions)
            where ResultT : EntityBase, new()
        {
            //返回的結果集
            List<ResultT> resultList = new List<ResultT>();
            rowsCount = 0;
            var sqlSelect = string.Empty;
            Dictionary<string, PropertyInfo> propertieList = null;
            var sqlParameters = GetListSqlByPageSearchEntity(searchEntity, resultEntity, out sqlSelect, ref propertieList,
                pageIndex, pageSize, tableName, orderBy, orderByEnum, excludeExpressions);
            if (!string.IsNullOrEmpty(sqlSelect) && propertieList != null && propertieList.Count > 0)
            {
                resultList = GetExecuteResultTeskNew<ResultT>(sqlSelect, out rowsCount, sqlParameters, propertieList);
                sqlParameters.Clear();
            }
            return resultList;
        }

        /// <summary>
        /// [新]根據查詢實體獲取查詢結果
        /// </summary>
        /// <typeparam name="SearchT">查詢實體類型</typeparam>
        /// <typeparam name="ResultT">響應結果類型</typeparam>
        /// <param name="searchEntity">查詢實體對象</param>
        /// <param name="resultEntity">響應結果對象</param>
        /// <param name="pageIndex">頁索引</param>
        /// <param name="pageSize">頁大小</param>
        /// <param name="rowsCount">返回行總數</param>
        /// <param name="dataBaseName">庫名</param>
        /// <param name="tableName">表名</param>
        /// <param name="orderBy">排序列名[多個請用逗號分開,注意最後一個不要指定排序方式]</param>
        /// <param name="orderByEnum">排序方式</param>
        /// <param name="excludeExpressions">過濾屬性集合</param>
        /// <returns></returns>
        public static List<ResultT> GetListByPageSearchEntityNew<SearchT, ResultT>(SearchT searchEntity, ResultT resultEntity,
            int pageIndex, int pageSize, out int rowsCount, string dataBaseName, string tableName, string orderBy = "", OrderByEnum orderByEnum = OrderByEnum.Desc,
            params Expression<Func<ResultT, object>>[] excludeExpressions)
            where ResultT : EntityBase, new()
        {
            //返回的結果集
            List<ResultT> resultList = new List<ResultT>();
            rowsCount = 0;
            var sqlSelect = string.Empty;
            Dictionary<string, PropertyInfo> propertieList = null;
            var sqlParameters = GetListSqlByPageSearchEntity(searchEntity, resultEntity, out sqlSelect, ref propertieList,
                pageIndex, pageSize, tableName, orderBy, orderByEnum, excludeExpressions);
            if (!string.IsNullOrEmpty(sqlSelect) && propertieList != null && propertieList.Count > 0)
            {
                resultList = GetExecuteResultTeskNew<ResultT>(sqlSelect, out rowsCount, sqlParameters, propertieList, dataBaseName);
                sqlParameters.Clear();
            }
            return resultList;
        }

        /// <summary>
        /// [新]根據查詢實體獲取查詢結果[SQL_CALC_FOUND_ROWS;SELECT FOUND_ROWS()一次性取出分頁數據和知足條件的全部數據行]
        /// </summary>
        /// <typeparam name="SearchT">查詢實體類型</typeparam>
        /// <typeparam name="ResultT">響應結果類型</typeparam>
        /// <param name="searchEntity">查詢實體對象</param>
        /// <param name="resultEntity">響應結果對象</param>
        /// <param name="sqlSelect">輸出查詢SQL</param>
        /// <param name="propertieList">實體屬性集合</param>
        /// <param name="pageIndex">頁索引</param>
        /// <param name="pageSize">頁大小</param>
        /// <param name="rowsCount">返回行總數</param>
        /// <param name="tableName">表名</param>
        /// <param name="orderBy">排序列名[多個請用逗號分開,注意最後一個不要指定排序方式]</param>
        /// <param name="orderByEnum">排序方式</param>
        /// <param name="excludeExpressions">過濾屬性集合</param>
        /// <returns></returns>
        public static List<MySqlParameter> GetListSqlByPageSearchEntity<SearchT, ResultT>(SearchT searchEntity, ResultT resultEntity,
            out string sqlSelect, ref Dictionary<string, PropertyInfo> propertieList, int pageIndex, int pageSize,
            string tableName, string orderBy = "", OrderByEnum orderByEnum = OrderByEnum.Desc,
            params Expression<Func<ResultT, object>>[] excludeExpressions)
            where ResultT : EntityBase, new()
        {
            var sqlParameters = new List<MySqlParameter>();
            sqlSelect = string.Empty;
            //sqlCount = string.Empty;
            if (searchEntity != null && resultEntity != null)
            {
                var typeSearch = searchEntity.GetType();
                var typeResult = resultEntity.GetType();
                tableName = GetTableName(typeResult, tableName);

                if (!string.IsNullOrEmpty(tableName))
                {
                    StringBuilder SelectSql = new StringBuilder();
                    SelectSql.Append("Select SQL_CALC_FOUND_ROWS ");
                    //StringBuilder CountSql = new StringBuilder();
                    //CountSql.AppendFormat("Select count(0) From {0}", tableName);
                    StringBuilder WhereSql = new StringBuilder(" Where");
                    WhereSql.Append(" RowStatus = 0");

                    //返回屬性
                    propertieList = GetProperties(typeResult);

                    //更新條件屬性集合和參數集合
                    Dictionary<string, object> excludeColumnList = new Dictionary<string, object>();
                    //過濾不返回屬性
                    if (excludeExpressions != null && excludeExpressions.Count() > 0)
                    {
                        var excludeColumns = (from c in excludeExpressions select c).ToArray();

                        //是否收整理過濾屬性
                        if (propertieList != null && propertieList.Count() > 0)
                        {
                            foreach (var item in excludeColumns)
                            {
                                var propertyName = GetExpressionsPropertyName<ResultT>(item);
                                if (!string.IsNullOrEmpty(propertyName))
                                {
                                    //獲取條件列名
                                    excludeColumnList.Add(propertyName, propertyName);
                                }
                            }
                        }
                    }

                    var searchPropertieList = GetProperties(typeSearch);
                    //整理查詢條件屬性和參數
                    foreach (var item in searchPropertieList.Values)
                    {
                        //驗證值是否有效
                        if (WhereValueValidate<SearchT>(searchEntity, item))
                        {
                            GetQueryWhere<SearchT>(searchEntity, sqlParameters, WhereSql, item);
                        }
                    }
                    //CountSql.Append(WhereSql);
                    foreach (var item in propertieList.Values)
                    {
                        var isKey = false;
                        //是否添加查詢屬性
                        if (ValidateIsAddPropertie(typeResult, item, OperationType.Select, excludeColumnList, out isKey))
                        {
                            SelectSql.AppendFormat("{0},", item.Name);
                        }
                        if (isKey && string.IsNullOrEmpty(orderBy))
                        {
                            //默認主鍵降序排列
                            orderBy = item.Name;
                        }
                    }
                    if (SelectSql.Length > 7)
                    {
                        SelectSql.Remove(SelectSql.Length - 1, 1);
                    }
                    SelectSql.AppendFormat(" FROM {0} ", tableName);
                    SelectSql.Append(WhereSql);
                    if (!string.IsNullOrEmpty(orderBy))
                    {
                        SelectSql.AppendFormat(" ORDER BY {0} {1}", orderBy, orderByEnum);
                    }
                    SelectSql.AppendFormat(" LIMIT {0},{1}; SELECT FOUND_ROWS()", (pageIndex - 1) * pageSize, pageSize);
                    sqlSelect = SelectSql.ToString();
                    //sqlCount = CountSql.ToString();
                }
            }
            return sqlParameters;
        }
相關文章
相關標籤/搜索