/// <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; }