/// <summary> /// Customs the non query criteria. /// </summary> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <returns></returns> /// <exception cref="AttributeNotFoundException"></exception> public static bool CustomNonQueryCriteria(Type type, Criteria criteria) { CheckTypeAtrribute(type); try { //Commit Filters criteria.CommitFilters(); return(ActiveRecordMaster.ExecuteNonQueryCriteria(type, criteria)); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.CustomNonQueryCriteria(type: [{0}], criteria: [{1}])", type, criteria), ex); return(false); } }
/// <summary> /// Returns only a selected field of all itens on criteria /// </summary> /// <typeparam name="TProjectionType">The type of the projection type.</typeparam> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <param name="field">The field.</param> /// <returns></returns> public static List <TProjectionType> ProjectionFindAll <TProjectionType>(Type type, Criteria criteria, string field) { CheckTypeAtrribute(type); try { criteria.SQLString = ActiveRecordMaster.MakeProjectionFullSelect(type, field); //Commit Filters criteria.CommitFilters(); return(ActiveRecordMaster.ExecuteProjectionQueryCriteria <TProjectionType>(criteria)); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.FindAll(type: [{0}])", type), ex); return(null); } }
/// <summary> /// Finds all. /// </summary> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <returns></returns> public static List <ActiveRecordBase> FindAll(Type type, Criteria criteria) { CheckTypeAtrribute(type); try { criteria.SQLString = ActiveRecordMaster.MakeFullSelect(type); //Commit Filters criteria.CommitFilters(); return(ActiveRecordMaster.ExecuteQueryCriteria(type, criteria)); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.FindAll(type: [{0}])", type), ex); throw ex; } }
/// <summary> /// Customs the find all. /// </summary> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <param name="customSQL">The custom SQL.</param> /// <returns></returns> /// <exception cref="AttributeNotFoundException"></exception> public static List <ActiveRecordBase> CustomFindAll(Type type, Criteria criteria, string customSQL) { CheckTypeAtrribute(type); try { criteria.SQLString = customSQL; //Commit Filters criteria.CommitFilters(); return(ActiveRecordMaster.ExecuteQueryCriteria(type, criteria)); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.CustomFindAll(type: [{0}], customSQL: [{1}])", type, customSQL), ex); return(null); } }
/// <summary> /// Return a portion of the itens on the criteria. /// </summary> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <param name="currentPage">The current page.</param> /// <param name="pageSize">Size of the page.</param> /// <param name="numberOfPages">The number of pages.</param> /// <param name="numberOfItems">The number of items.</param> /// <param name="findNumberOfPages">if set to <c>true</c> [find number of pages].</param> /// <returns></returns> /// <exception cref="AttributeNotFoundException"></exception> public static List <ActiveRecordBase> SlicedFindAll(Type type, Criteria criteria, int currentPage, int pageSize, out int numberOfPages, out int numberOfItems, bool findNumberOfPages) { CheckTypeAtrribute(type); try { if (findNumberOfPages) { //Count float count = ActiveRecordBase.Count(type, criteria); numberOfItems = (int)count; count = ((float)count / pageSize); numberOfPages = (count) != ((int)count) ? ((int)count) + 1 : ((int)count); } else { numberOfItems = -1; numberOfPages = -1; } //Query criteria.IncludeOrderBy = true; criteria.SQLString = ActiveRecordMaster.MakeFullSelect(type); criteria.CommitFilters(); //.CommitSlicedFilters((currentPage - 1) * pageSize, pageSize); //MakePaginator criteria.MakePaginator(currentPage, pageSize); return(ActiveRecordMaster.ExecuteQueryCriteria(type, criteria)); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.SlicedFindAll(type: [{0}])", type), ex); numberOfItems = 0; numberOfPages = 0; return(null); } }
/// <summary> /// Return the number of items /// </summary> /// <param name="type">The type.</param> /// <param name="criteria">The criteria.</param> /// <returns></returns> public static int Count(Type type, Criteria criteria) { CheckTypeAtrribute(type); try { criteria.SQLString = ActiveRecordMaster.MakeCountSelect(type); //Commit Filters criteria.IncludeOrderBy = false; criteria.CommitFilters(); object count = ActiveRecordMaster.ExecuteScalarQueryCriteria(type, criteria); return(int.Parse(count.ToString())); } catch (Exception ex) { LogManager.Log("Monty.ActiveRecord", LogCategory.Error, String.Format("Error when tries to execute ActiveRecordBase.Count(type: [{0}])", type), ex); return(0); } }