function getByCompanyId($company_id, $where = NULL, $order = NULL) { if ($company_id == '') { return FALSE; } $rscf = new RecurringScheduleControlFactory(); $ph = array('company_id' => $company_id); $query = ' select a.* from ' . $this->getTable() . ' as a LEFT JOIN ' . $rscf->getTable() . ' as rscf ON a.recurring_schedule_control_id = rscf.id where rscf.company_id = ? AND ( rscf.deleted = 0 )'; $query .= $this->getWhereSQL($where); $query .= $this->getSortSQL($order); $this->ExecuteSQL($query, $ph); return $this; }
function getSearchByCompanyIdAndArrayCriteria($company_id, $filter_data, $limit = NULL, $page = NULL, $where = NULL, $order = NULL) { if ($company_id == '') { return FALSE; } if (!is_array($order)) { //Use Filter Data ordering if its set. if (isset($filter_data['sort_column']) and $filter_data['sort_order']) { $order = array(Misc::trimSortPrefix($filter_data['sort_column']) => $filter_data['sort_order']); } } //Debug::Arr($order,'aOrder Data:', __FILE__, __LINE__, __METHOD__,10); $additional_order_fields = array('name', 'description', 'last_name', 'start_date', 'user_id'); if ($order == NULL) { $order = array('c.start_date' => 'asc', 'cb.user_id' => 'desc', 'a.week' => 'asc'); $strict = FALSE; } else { $strict = TRUE; } if (isset($filter_data['exclude_user_ids'])) { $filter_data['exclude_id'] = $filter_data['exclude_user_ids']; } //This is used by Flex Schedule Summary report. if (isset($filter_data['include_user_id'])) { $filter_data['id'] = $filter_data['include_user_id']; } if (isset($filter_data['include_user_ids'])) { $filter_data['id'] = $filter_data['include_user_ids']; } /* if ( isset($filter_data['user_status_ids']) ) { $filter_data['status_id'] = $filter_data['user_status_ids']; } */ if (isset($filter_data['user_title_ids'])) { $filter_data['title_id'] = $filter_data['user_title_ids']; } if (isset($filter_data['group_ids'])) { $filter_data['group_id'] = $filter_data['group_ids']; } if (isset($filter_data['default_branch_ids'])) { $filter_data['default_branch_id'] = $filter_data['default_branch_ids']; } if (isset($filter_data['default_department_ids'])) { $filter_data['default_department_id'] = $filter_data['default_department_ids']; } if (isset($filter_data['branch_ids'])) { $filter_data['schedule_branch_id'] = $filter_data['branch_ids']; } if (isset($filter_data['department_ids'])) { $filter_data['schedule_department_id'] = $filter_data['department_ids']; } if (isset($filter_data['schedule_branch_ids'])) { $filter_data['schedule_branch_id'] = $filter_data['schedule_branch_ids']; } if (isset($filter_data['schedule_department_ids'])) { $filter_data['schedule_department_id'] = $filter_data['schedule_department_ids']; } if (isset($filter_data['exclude_job_ids'])) { $filter_data['exclude_id'] = $filter_data['exclude_job_ids']; } if (isset($filter_data['include_job_ids'])) { $filter_data['include_job_id'] = $filter_data['include_job_ids']; } if (isset($filter_data['job_group_ids'])) { $filter_data['job_group_id'] = $filter_data['job_group_ids']; } if (isset($filter_data['job_item_ids'])) { $filter_data['job_item_id'] = $filter_data['job_item_ids']; } //Debug::Arr($order,'bOrder Data:', __FILE__, __LINE__, __METHOD__,10); //Debug::Arr($filter_data,'Filter Data:', __FILE__, __LINE__, __METHOD__,10); $uf = new UserFactory(); $uwf = new UserWageFactory(); $rscf = new RecurringScheduleControlFactory(); $rsuf = new RecurringScheduleUserFactory(); $rstcf = new RecurringScheduleTemplateControlFactory(); $bf = new BranchFactory(); $df = new DepartmentFactory(); $ugf = new UserGroupFactory(); $utf = new UserTitleFactory(); $apf = new AbsencePolicyFactory(); $ppsuf = new PayPeriodScheduleUserFactory(); $ppsf = new PayPeriodScheduleFactory(); if (getTTProductEdition() >= TT_PRODUCT_CORPORATE) { $jf = new JobFactory(); $jif = new JobItemFactory(); } $ph = array('filter_end_date' => $this->db->BindDate($filter_data['end_date']), 'company_id' => $company_id); $query = ' select a.*, apf.type_id as absence_policy_type_id, apf.name as absence_policy, cb.user_id as user_id, CASE WHEN a.branch_id = -1 THEN d.default_branch_id ELSE a.branch_id END as schedule_branch_id, CASE WHEN a.branch_id = -1 THEN bf.name ELSE bfb.name END as schedule_branch, CASE WHEN a.department_id = -1 THEN d.default_department_id ELSE a.department_id END as schedule_department_id, CASE WHEN a.department_id = -1 THEN df.name ELSE dfb.name END as schedule_department, c.start_date as recurring_schedule_control_start_date, c.end_date as recurring_schedule_control_end_date, c.start_week as recurring_schedule_control_start_week, zz.max_week as max_week, ( (((a.week-1)+zz.max_week-(c.start_week-1))%zz.max_week) + 1) as remapped_week, d.first_name as first_name, d.last_name as last_name, d.default_branch_id as default_branch_id, bf.name as default_branch, d.default_department_id as default_department_id, df.name as default_department, d.title_id as title_id, utf.name as title, d.group_id as group_id, ugf.name as "group", d.created_by as user_created_by, d.hire_date as hire_date, d.termination_date as termination_date, uw.id as user_wage_id, uw.hourly_rate as user_wage_hourly_rate, uw.effective_date as user_wage_effective_date, ppsf.shift_assigned_day_id as shift_assigned_day_id, c.created_by as recurring_schedule_control_created_by '; if (getTTProductEdition() >= TT_PRODUCT_CORPORATE) { $query .= ', x.name as job, x.status_id as job_status_id, x.manual_id as job_manual_id, x.branch_id as job_branch_id, x.department_id as job_department_id, x.group_id as job_group_id, y.name as job_item, y.manual_id as job_item_manual_id, y.group_id as job_item_group_id'; } //Since when dealing with recurring schedules, we don't have a row for each specific date, so when determining wages //we can only use the last wage entered that is earlier than the filter end date. //Since in theory committed schedules will occur before todays date anyways, the accuracy won't be off too much unless //the end date they specify is really far in the future, and post dated wage entry is also made. $query .= ' from ' . $this->getTable() . ' as a LEFT JOIN ( select z.recurring_schedule_template_control_id, max(z.week) as max_week from recurring_schedule_template as z where deleted = 0 group by z.recurring_schedule_template_control_id ) as zz ON a.recurring_schedule_template_control_id = zz.recurring_schedule_template_control_id LEFT JOIN ' . $rstcf->getTable() . ' as b ON a.recurring_schedule_template_control_id = b.id LEFT JOIN ' . $rscf->getTable() . ' as c ON a.recurring_schedule_template_control_id = c.recurring_schedule_template_control_id LEFT JOIN ' . $rsuf->getTable() . ' as cb ON c.id = cb.recurring_schedule_control_id LEFT JOIN ' . $uf->getTable() . ' as d ON cb.user_id = d.id LEFT JOIN ' . $ppsuf->getTable() . ' as ppsuf ON d.id = ppsuf.user_id LEFT JOIN ' . $ppsf->getTable() . ' as ppsf ON ( ppsuf.pay_period_schedule_id = ppsf.id AND ppsf.deleted = 0 ) LEFT JOIN ' . $bf->getTable() . ' as bf ON ( d.default_branch_id = bf.id AND bf.deleted = 0) LEFT JOIN ' . $bf->getTable() . ' as bfb ON ( a.branch_id = bfb.id AND bfb.deleted = 0) LEFT JOIN ' . $df->getTable() . ' as df ON ( d.default_department_id = df.id AND df.deleted = 0) LEFT JOIN ' . $df->getTable() . ' as dfb ON ( a.department_id = dfb.id AND dfb.deleted = 0) LEFT JOIN ' . $ugf->getTable() . ' as ugf ON ( d.group_id = ugf.id AND ugf.deleted = 0 ) LEFT JOIN ' . $utf->getTable() . ' as utf ON ( d.title_id = utf.id AND utf.deleted = 0 ) LEFT JOIN ' . $apf->getTable() . ' as apf ON ( a.absence_policy_id = apf.id AND apf.deleted = 0 ) LEFT JOIN ' . $uwf->getTable() . ' as uw ON uw.id = (select uwb.id from ' . $uwf->getTable() . ' as uwb where uwb.user_id = cb.user_id and uwb.effective_date <= ? and uwb.deleted = 0 order by uwb.effective_date desc limit 1) '; if (getTTProductEdition() >= TT_PRODUCT_CORPORATE) { $query .= ' LEFT JOIN ' . $jf->getTable() . ' as x ON a.job_id = x.id'; $query .= ' LEFT JOIN ' . $jif->getTable() . ' as y ON a.job_item_id = y.id'; } $query .= ' where b.company_id = ? '; if (isset($filter_data['permission_children_ids']) and isset($filter_data['permission_children_ids'][0]) and !in_array(-1, (array) $filter_data['permission_children_ids'])) { $query .= ' AND d.id in (' . $this->getListSQL($filter_data['permission_children_ids'], $ph) . ') '; } if (isset($filter_data['id']) and isset($filter_data['id'][0]) and !in_array(-1, (array) $filter_data['id'])) { $query .= ' AND d.id in (' . $this->getListSQL($filter_data['id'], $ph) . ') '; } if (isset($filter_data['exclude_id']) and isset($filter_data['exclude_id'][0]) and !in_array(-1, (array) $filter_data['exclude_id'])) { $query .= ' AND d.id not in (' . $this->getListSQL($filter_data['exclude_id'], $ph) . ') '; } if (isset($filter_data['user_status_id']) and isset($filter_data['user_status_id'][0]) and !in_array(-1, (array) $filter_data['user_status_id'])) { $query .= ' AND d.status_id in (' . $this->getListSQL($filter_data['user_status_id'], $ph) . ') '; } if (isset($filter_data['status_id']) and isset($filter_data['status_id'][0]) and !in_array(-1, (array) $filter_data['status_id'])) { $query .= ' AND a.status_id in (' . $this->getListSQL($filter_data['status_id'], $ph) . ') '; } if (isset($filter_data['group_id']) and isset($filter_data['group_id'][0]) and !in_array(-1, (array) $filter_data['group_id'])) { if (isset($filter_data['include_subgroups']) and (bool) $filter_data['include_subgroups'] == TRUE) { $uglf = new UserGroupListFactory(); $filter_data['group_id'] = $uglf->getByCompanyIdAndGroupIdAndSubGroupsArray($company_id, $filter_data['group_id'], TRUE); } $query .= ' AND d.group_id in (' . $this->getListSQL($filter_data['group_id'], $ph) . ') '; } if (isset($filter_data['default_branch_id']) and isset($filter_data['default_branch_id'][0]) and !in_array(-1, (array) $filter_data['default_branch_id'])) { $query .= ' AND d.default_branch_id in (' . $this->getListSQL($filter_data['default_branch_id'], $ph) . ') '; } if (isset($filter_data['default_department_id']) and isset($filter_data['default_department_id'][0]) and !in_array(-1, (array) $filter_data['default_department_id'])) { $query .= ' AND d.default_department_id in (' . $this->getListSQL($filter_data['default_department_id'], $ph) . ') '; } if (isset($filter_data['schedule_branch_id']) and isset($filter_data['schedule_branch_id'][0]) and !in_array(-1, (array) $filter_data['schedule_branch_id'])) { $query .= ' AND ( a.branch_id in (' . $this->getListSQL($filter_data['schedule_branch_id'], $ph) . ') OR ( a.branch_id = -1 AND d.default_branch_id in (' . $this->getListSQL($filter_data['schedule_branch_id'], $ph) . ') ) )'; } if (isset($filter_data['schedule_department_id']) and isset($filter_data['schedule_department_id'][0]) and !in_array(-1, (array) $filter_data['schedule_department_id'])) { $query .= ' AND ( a.department_id in (' . $this->getListSQL($filter_data['schedule_department_id'], $ph) . ') OR ( a.department_id = -1 AND d.default_department_id in (' . $this->getListSQL($filter_data['schedule_department_id'], $ph) . ') ) )'; } if (isset($filter_data['title_id']) and isset($filter_data['title_id'][0]) and !in_array(-1, (array) $filter_data['title_id'])) { $query .= ' AND d.title_id in (' . $this->getListSQL($filter_data['title_id'], $ph) . ') '; } //Use the job_id in the schedule table so we can filter by '0' or No Job if (isset($filter_data['job_id']) and isset($filter_data['job_id'][0]) and !in_array(-1, (array) $filter_data['job_id'])) { $query .= ' AND a.job_id in (' . $this->getListSQL($filter_data['job_id'], $ph) . ') '; } if (isset($filter_data['job_group_id']) and isset($filter_data['job_group_id'][0]) and !in_array(-1, (array) $filter_data['job_group_id'])) { if (isset($filter_data['include_job_subgroups']) and (bool) $filter_data['include_job_subgroups'] == TRUE) { $uglf = new UserGroupListFactory(); $filter_data['job_group_id'] = $uglf->getByCompanyIdAndGroupIdAndjob_subgroupsArray($company_id, $filter_data['job_group_id'], TRUE); } $query .= ' AND x.group_id in (' . $this->getListSQL($filter_data['job_group_id'], $ph) . ') '; } if (isset($filter_data['job_item_id']) and isset($filter_data['job_item_id'][0]) and !in_array(-1, (array) $filter_data['job_item_id'])) { $query .= ' AND a.job_item_id in (' . $this->getListSQL($filter_data['job_item_id'], $ph) . ') '; } if (isset($filter_data['start_date']) and trim($filter_data['start_date']) != '' and isset($filter_data['end_date']) and trim($filter_data['end_date']) != '') { $start_date_stamp = $this->db->BindDate($filter_data['start_date']); $end_date_stamp = $this->db->BindDate($filter_data['end_date']); $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $filter_data['end_date']; $ph[] = $filter_data['start_date']; $query .= ' AND ( (c.start_date >= ? AND c.start_date <= ? AND c.end_date IS NULL ) OR (c.start_date <= ? AND c.end_date IS NULL ) OR (c.start_date <= ? AND c.end_date >= ? ) OR (c.start_date >= ? AND c.end_date <= ? ) OR (c.start_date >= ? AND c.start_date <= ? ) OR (c.end_date >= ? AND c.end_date <= ? ) OR (c.start_date <= ? AND c.end_date >= ? ) ) AND ( ( d.hire_date is NULL OR d.hire_date <= ? ) AND ( d.termination_date is NULL OR d.termination_date >= ? ) ) '; } $query .= ' AND ( a.deleted = 0 AND b.deleted = 0 AND c.deleted = 0 AND (d.deleted is NULL OR d.deleted = 0 ) ) '; $query .= $this->getWhereSQL($where); $query .= $this->getSortSQL($order, $strict, $additional_order_fields); //Debug::Arr($ph,' Query: '. $query, __FILE__, __LINE__, __METHOD__,10); $this->ExecuteSQL($query, $ph, $limit, $page); return $this; }
function getSearchByCompanyIdAndArrayCriteria($company_id, $filter_data, $limit = NULL, $page = NULL, $where = NULL, $order = NULL) { if ($company_id == '') { return FALSE; } if (!is_array($order)) { //Use Filter Data ordering if its set. if (isset($filter_data['sort_column']) and $filter_data['sort_order']) { $order = array(Misc::trimSortPrefix($filter_data['sort_column']) => $filter_data['sort_order']); } } Debug::Arr($order, 'aOrder Data:', __FILE__, __LINE__, __METHOD__, 10); $additional_order_fields = array('name', 'description', 'last_name'); if ($order == NULL) { $order = array('c.start_date' => 'asc', 'd.user_id' => 'asc', 'a.week' => 'asc'); $strict = FALSE; } else { $strict = TRUE; } if (isset($filter_data['exclude_user_ids'])) { $filter_data['exclude_id'] = $filter_data['exclude_user_ids']; } if (isset($filter_data['include_user_ids'])) { $filter_data['id'] = $filter_data['include_user_ids']; } if (isset($filter_data['user_status_ids'])) { $filter_data['status_id'] = $filter_data['user_status_ids']; } if (isset($filter_data['user_title_ids'])) { $filter_data['title_id'] = $filter_data['user_title_ids']; } if (isset($filter_data['group_ids'])) { $filter_data['group_id'] = $filter_data['group_ids']; } if (isset($filter_data['default_branch_ids'])) { $filter_data['default_branch_id'] = $filter_data['default_branch_ids']; } if (isset($filter_data['default_department_ids'])) { $filter_data['default_department_id'] = $filter_data['default_department_ids']; } if (isset($filter_data['schedule_branch_ids'])) { $filter_data['schedule_branch_id'] = $filter_data['schedule_branch_ids']; } if (isset($filter_data['schedule_department_ids'])) { $filter_data['schedule_department_id'] = $filter_data['schedule_department_ids']; } if (isset($filter_data['exclude_job_ids'])) { $filter_data['exclude_id'] = $filter_data['exclude_job_ids']; } if (isset($filter_data['include_job_ids'])) { $filter_data['include_job_id'] = $filter_data['include_job_ids']; } if (isset($filter_data['job_group_ids'])) { $filter_data['job_group_id'] = $filter_data['job_group_ids']; } if (isset($filter_data['job_item_ids'])) { $filter_data['job_item_id'] = $filter_data['job_item_ids']; } Debug::Arr($order, 'bOrder Data:', __FILE__, __LINE__, __METHOD__, 10); Debug::Arr($filter_data, 'Filter Data:', __FILE__, __LINE__, __METHOD__, 10); $uf = new UserFactory(); $rscf = new RecurringScheduleControlFactory(); $rsuf = new RecurringScheduleUserFactory(); $rstcf = new RecurringScheduleTemplateControlFactory(); $ph = array('company_id' => $company_id); $query = ' select a.*, d.user_id as user_id, e.first_name as first_name, e.last_name as last_name, e.created_by as user_created_by, CASE WHEN a.branch_id = -1 THEN e.default_branch_id ELSE a.branch_id END as schedule_branch_id, CASE WHEN a.department_id = -1 THEN e.default_department_id ELSE a.department_id END as schedule_department_id, c.start_date as recurring_schedule_control_start_date, c.end_date as recurring_schedule_control_end_date, c.start_week as recurring_schedule_control_start_week, y.max_week as max_week, ( (((a.week-1)+y.max_week-(c.start_week-1))%y.max_week) + 1) as remapped_week, e.hire_date as hire_date, e.termination_date as termination_date from ' . $this->getTable() . ' as a LEFT JOIN ( select z.recurring_schedule_template_control_id, max(z.week) as max_week from recurring_schedule_template as z where deleted = 0 group by z.recurring_schedule_template_control_id ) as y ON a.recurring_schedule_template_control_id = y.recurring_schedule_template_control_id LEFT JOIN ' . $rstcf->getTable() . ' as b ON a.recurring_schedule_template_control_id = b.id LEFT JOIN ' . $rscf->getTable() . ' as c ON a.recurring_schedule_template_control_id = c.recurring_schedule_template_control_id LEFT JOIN ' . $rsuf->getTable() . ' as d ON c.id = d.recurring_schedule_control_id LEFT JOIN ' . $uf->getTable() . ' as e ON d.user_id = e.id where b.company_id = ? '; if (isset($filter_data['id']) and isset($filter_data['id'][0]) and !in_array(-1, (array) $filter_data['id'])) { $query .= ' AND e.id in (' . $this->getListSQL($filter_data['id'], $ph) . ') '; } if (isset($filter_data['permission_children_ids']) and isset($filter_data['permission_children_ids'][0]) and !in_array(-1, (array) $filter_data['permission_children_ids'])) { $query .= ' AND e.id in (' . $this->getListSQL($filter_data['permission_children_ids'], $ph) . ') '; } if (isset($filter_data['status_id']) and isset($filter_data['status_id'][0]) and !in_array(-1, (array) $filter_data['status_id'])) { $query .= ' AND e.status_id in (' . $this->getListSQL($filter_data['status_id'], $ph) . ') '; } if (isset($filter_data['group_id']) and isset($filter_data['group_id'][0]) and !in_array(-1, (array) $filter_data['group_id'])) { if (isset($filter_data['include_subgroups']) and (bool) $filter_data['include_subgroups'] == TRUE) { $uglf = new UserGroupListFactory(); $filter_data['group_id'] = $uglf->getByCompanyIdAndGroupIdAndSubGroupsArray($company_id, $filter_data['group_id'], TRUE); } $query .= ' AND e.group_id in (' . $this->getListSQL($filter_data['group_id'], $ph) . ') '; } if (isset($filter_data['default_branch_id']) and isset($filter_data['default_branch_id'][0]) and !in_array(-1, (array) $filter_data['default_branch_id'])) { $query .= ' AND e.default_branch_id in (' . $this->getListSQL($filter_data['default_branch_id'], $ph) . ') '; } if (isset($filter_data['default_department_id']) and isset($filter_data['default_department_id'][0]) and !in_array(-1, (array) $filter_data['default_department_id'])) { $query .= ' AND e.default_department_id in (' . $this->getListSQL($filter_data['default_department_id'], $ph) . ') '; } if (isset($filter_data['schedule_branch_id']) and isset($filter_data['schedule_branch_id'][0]) and !in_array(-1, (array) $filter_data['schedule_branch_id'])) { $query .= ' AND ( a.branch_id in (' . $this->getListSQL($filter_data['schedule_branch_id'], $ph) . ') OR ( a.branch_id = -1 AND e.default_branch_id in (' . $this->getListSQL($filter_data['schedule_branch_id'], $ph) . ') ) )'; } if (isset($filter_data['schedule_department_id']) and isset($filter_data['schedule_department_id'][0]) and !in_array(-1, (array) $filter_data['schedule_department_id'])) { $query .= ' AND ( a.department_id in (' . $this->getListSQL($filter_data['schedule_department_id'], $ph) . ') OR ( a.department_id = -1 AND e.default_department_id in (' . $this->getListSQL($filter_data['schedule_department_id'], $ph) . ') ) )'; } if (isset($filter_data['title_id']) and isset($filter_data['title_id'][0]) and !in_array(-1, (array) $filter_data['title_id'])) { $query .= ' AND e.title_id in (' . $this->getListSQL($filter_data['title_id'], $ph) . ') '; } if (isset($filter_data['start_date']) and trim($filter_data['start_date']) != '' and isset($filter_data['end_date']) and trim($filter_data['end_date']) != '') { $start_date_stamp = $this->db->BindDate($filter_data['start_date']); $end_date_stamp = $this->db->BindDate($filter_data['end_date']); $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $start_date_stamp; $ph[] = $end_date_stamp; $ph[] = $filter_data['end_date']; $ph[] = $filter_data['start_date']; $query .= ' AND ( (c.start_date >= ? AND c.start_date <= ? AND c.end_date IS NULL ) OR (c.start_date <= ? AND c.end_date IS NULL ) OR (c.start_date <= ? AND c.end_date >= ? ) OR (c.start_date >= ? AND c.end_date <= ? ) OR (c.start_date >= ? AND c.start_date <= ? ) OR (c.end_date >= ? AND c.end_date <= ? ) OR (c.start_date <= ? AND c.end_date >= ? ) ) AND ( ( e.hire_date is NULL OR e.hire_date <= ? ) AND ( e.termination_date is NULL OR e.termination_date >= ? ) ) '; } $query .= ' AND ( a.deleted = 0 AND b.deleted = 0 AND c.deleted = 0 AND e.deleted = 0 ) '; $query .= $this->getWhereSQL($where); $query .= $this->getSortSQL($order, $strict, $additional_order_fields); Debug::Text('Query: ' . $query, __FILE__, __LINE__, __METHOD__, 10); if ($limit == NULL) { $this->rs = $this->db->Execute($query, $ph); } else { $this->rs = $this->db->PageExecute($query, $limit, $page, $ph); } return $this; }