public SalesByCategoryCollectionResponse Fetch(SalesByCategoryQueryCollectionRequest request) { base.FixupLimitAndPagingOnRequest(request); var totalItemCount = 0; var sortExpression = RepositoryHelper.ConvertStringToSortExpression(TypedViewType, request.Sort); var includedFieldNames = RepositoryHelper.ConvertStringToExcludedIncludedFields(request.Select); var predicateBucket = RepositoryHelper.ConvertStringToRelationPredicateBucket(TypedViewType, request.Filter); var typedView = new SalesByCategoryTypedView(); using (var adapter = DataAccessAdapterFactory.NewDataAccessAdapter()) { OnBeforeFetchSalesByCategoryQueryCollectionRequest(adapter, request, sortExpression, includedFieldNames, predicateBucket, request.PageNumber, request.PageSize, request.Limit); totalItemCount = (int)adapter.GetDbCount(typedView.GetFieldsInfo(), predicateBucket, null, false); adapter.FetchTypedView(typedView.GetFieldsInfo(), typedView, predicateBucket, request.Limit, sortExpression, true, null, request.PageNumber, request.PageSize); OnAfterFetchSalesByCategoryQueryCollectionRequest(adapter, request, typedView, sortExpression, includedFieldNames, predicateBucket, request.PageNumber, request.PageSize, request.Limit, totalItemCount); } var dtos = new SalesByCategoryCollection(); var enumerator = typedView.GetEnumerator(); while (enumerator.MoveNext()) { dtos.Add(Map(enumerator.Current, includedFieldNames)); } var response = new SalesByCategoryCollectionResponse(dtos, request.PageNumber, request.PageSize, totalItemCount); return(response); }
/// <summary>Queries 'SalesByCategory' typed view records using sorting, filtering, paging and more.</summary> public SalesByCategoryCollectionResponse Get(SalesByCategoryQueryCollectionRequest request) { OnBeforeGetSalesByCategoryQueryCollectionRequest(request); var output = Repository.Fetch(request); OnAfterGetSalesByCategoryQueryCollectionRequest(request, output); return(output); }
partial void OnAfterFetchSalesByCategoryQueryCollectionRequest(IDataAccessAdapter adapter, SalesByCategoryQueryCollectionRequest request, SalesByCategoryTypedView typedView, SortExpression sortExpression, string[] includedFieldNames, IRelationPredicateBucket predicateBucket, int pageNumber, int pageSize, int limit, int totalItemCount);
partial void OnBeforeFetchSalesByCategoryQueryCollectionRequest(IDataAccessAdapter adapter, SalesByCategoryQueryCollectionRequest request, SortExpression sortExpression, string[] includedFieldNames, IRelationPredicateBucket predicateBucket, int pageNumber, int pageSize, int limit);
partial void OnAfterGetSalesByCategoryQueryCollectionRequest(SalesByCategoryQueryCollectionRequest request, SalesByCategoryCollectionResponse response);
partial void OnBeforeGetSalesByCategoryQueryCollectionRequest(SalesByCategoryQueryCollectionRequest request);