public static function retrieveByPKs($pks, $con = null) { if ($con === null) { $con = Propel::getConnection(self::DATABASE_NAME); } $objs = null; if (empty($pks)) { $objs = array(); } else { $criteria = new Criteria(); $criteria->add(EmployeeAbsenceDevPeer::ID, $pks, Criteria::IN); $objs = EmployeeAbsenceDevPeer::doSelect($criteria, $con); } return $objs; }
public function fromArray($arr, $keyType = BasePeer::TYPE_PHPNAME) { $keys = EmployeeAbsenceDevPeer::getFieldNames($keyType); if (array_key_exists($keys[0], $arr)) { $this->setId($arr[$keys[0]]); } if (array_key_exists($keys[1], $arr)) { $this->setEmployeeId($arr[$keys[1]]); } if (array_key_exists($keys[2], $arr)) { $this->setAcademicCalendarId($arr[$keys[2]]); } if (array_key_exists($keys[3], $arr)) { $this->setStatus($arr[$keys[3]]); } if (array_key_exists($keys[4], $arr)) { $this->setStart($arr[$keys[4]]); } if (array_key_exists($keys[5], $arr)) { $this->setDateIn($arr[$keys[5]]); } if (array_key_exists($keys[6], $arr)) { $this->setDatang($arr[$keys[6]]); } }
public function filterAbsence($c, $filters) { $filters_key = array_keys($filters); foreach ($filters_key as $key) { $value = $filters[$key]; if ($value == '' || $value == null) { continue; } if ($key == 'EXTRA_CODE') { $c->addJoin(EmployeePeer::ID, EmployeeAbsenceDevPeer::EMPLOYEE_ID); $c->addJoin(EmployeeDetailPeer::EMPLOYEE_ID, EmployeePeer::ID); $column = EmployeeDetailPeer::getTableMap()->getColumn('EXTRA_CODE'); } elseif ($key == 'FINGERCODE') { $c->addJoin(EmployeePeer::ID, EmployeeAbsenceDevPeer::EMPLOYEE_ID); $c->addJoin(EmployeeDetailPeer::EMPLOYEE_ID, EmployeePeer::ID); $column = EmployeeDetailPeer::getTableMap()->getColumn('FINGERCODE'); } elseif ($key = 'EMP_NO') { $c->addJoin(EmployeePeer::ID, EmployeeAbsenceDevPeer::EMPLOYEE_ID); $column = EmployeePeer::getTableMap()->getColumn('CODE'); } elseif ($key = 'EMP_NAME') { $c->addJoin(EmployeePeer::ID, EmployeeAbsenceDevPeer::EMPLOYEE_ID); $column = EmployeePeer::getTableMap()->getColumn('NAME'); } elseif ($key = 'DEPARTMENT_ID') { $c->addJoin(EmployeePeer::ID, EmployeeAbsenceDevPeer::EMPLOYEE_ID); $c->addJoin(DepartmentPeer::ID, EmployeePeer::DEPARTMENT_ID); $column = DepartmentPeer::getTableMap()->getColumn('ID'); } elseif ($key = 'STATUS') { $column = EmployeeAbsenceDevPeer::getTableMap()->getColumn('STATUS'); } else { $column = EmployeeAbsenceDevPeer::getTableMap()->getColumn($key); } $name = $column->getFullyQualifiedName(); $creoleType = $column->getCreoleType(); if ($creoleType == CreoleTypes::TIMESTAMP) { $from = $value['from']; $to = $value['to']; if ($from != '' && $from != null) { $c->add($name, $from, Criteria::GREATER_EQUAL); } if ($to != '' && $to != null) { $c->add($name, $to, Criteria::LESS_EQUAL); } } elseif ($creoleType == CreoleTypes::DATE) { #$from = $value['from']; #$to = $value['to']; #if ($from != '' && $from != null) # $c->add($name, $from, Criteria::GREATER_EQUAL); #if ($to != '' && $to != null) # $c->add($name, $to, Criteria::LESS_EQUAL); $c->add($name, $value, Criteria::EQUAL); } elseif ($creoleType == CreoleTypes::INTEGER) { $c->add($name, $value, Criteria::EQUAL); } elseif ($creoleType == CreoleTypes::VARCHAR || $creoleType == CreoleTypes::CHAR) { $c->add($name, "%{$value}%", Criteria::LIKE); } } }