예제 #1
0
        /// <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);
            }
        }
예제 #2
0
        /// <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);
            }
        }
예제 #3
0
        /// <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;
            }
        }
예제 #4
0
        /// <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);
            }
        }
예제 #5
0
        /// <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);
            }
        }
예제 #6
0
        /// <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);
            }
        }