/** * Exports the object as an array. * * You can specify the key type of the array by passing one of the class * type constants. * * @param string $keyType (optional) One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_CAMELNAME, * TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM. * Defaults to TableMap::TYPE_PHPNAME. * @param boolean $includeLazyLoadColumns (optional) Whether to include lazy loaded columns. Defaults to TRUE. * @param array $alreadyDumpedObjects List of objects to skip to avoid recursion * @param boolean $includeForeignObjects (optional) Whether to include hydrated related objects. Default to FALSE. * * @return array an associative array containing the field names (as keys) and field values */ public function toArray($keyType = TableMap::TYPE_PHPNAME, $includeLazyLoadColumns = true, $alreadyDumpedObjects = array(), $includeForeignObjects = false) { if (isset($alreadyDumpedObjects['Subcategories'][$this->hashCode()])) { return '*RECURSION*'; } $alreadyDumpedObjects['Subcategories'][$this->hashCode()] = true; $keys = SubcategoriesTableMap::getFieldNames($keyType); $result = array($keys[0] => $this->getSubcategoryId(), $keys[1] => $this->getCategoryId(), $keys[2] => $this->getSubcategoryName()); $virtualColumns = $this->virtualColumns; foreach ($virtualColumns as $key => $virtualColumn) { $result[$key] = $virtualColumn; } if ($includeForeignObjects) { if (null !== $this->aCategories) { switch ($keyType) { case TableMap::TYPE_CAMELNAME: $key = 'categories'; break; case TableMap::TYPE_FIELDNAME: $key = 'Categories'; break; default: $key = 'Categories'; } $result[$key] = $this->aCategories->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } if (null !== $this->collItemss) { switch ($keyType) { case TableMap::TYPE_CAMELNAME: $key = 'itemss'; break; case TableMap::TYPE_FIELDNAME: $key = 'Itemss'; break; default: $key = 'Itemss'; } $result[$key] = $this->collItemss->toArray(null, false, $keyType, $includeLazyLoadColumns, $alreadyDumpedObjects); } } return $result; }
/** * Exports the object as an array. * * You can specify the key type of the array by passing one of the class * type constants. * * @param string $keyType (optional) One of the class type constants TableMap::TYPE_PHPNAME, TableMap::TYPE_CAMELNAME, * TableMap::TYPE_COLNAME, TableMap::TYPE_FIELDNAME, TableMap::TYPE_NUM. * Defaults to TableMap::TYPE_PHPNAME. * @param boolean $includeLazyLoadColumns (optional) Whether to include lazy loaded columns. Defaults to TRUE. * @param array $alreadyDumpedObjects List of objects to skip to avoid recursion * @param boolean $includeForeignObjects (optional) Whether to include hydrated related objects. Default to FALSE. * * @return array an associative array containing the field names (as keys) and field values */ public function toArray($keyType = TableMap::TYPE_PHPNAME, $includeLazyLoadColumns = true, $alreadyDumpedObjects = array(), $includeForeignObjects = false) { if (isset($alreadyDumpedObjects['Items'][$this->hashCode()])) { return '*RECURSION*'; } $alreadyDumpedObjects['Items'][$this->hashCode()] = true; $keys = ItemsTableMap::getFieldNames($keyType); $result = array($keys[0] => $this->getItemId(), $keys[1] => $this->getCategoryId(), $keys[2] => $this->getUserId(), $keys[3] => $this->getItemName(), $keys[4] => $this->getPrice(), $keys[5] => $this->getDescription(), $keys[6] => $this->getDateAdded(), $keys[7] => $this->getDateSold(), $keys[8] => $this->getSubcategoryId(), $keys[9] => $this->getImageUrl()); if ($result[$keys[6]] instanceof \DateTime) { $result[$keys[6]] = $result[$keys[6]]->format('c'); } if ($result[$keys[7]] instanceof \DateTime) { $result[$keys[7]] = $result[$keys[7]]->format('c'); } $virtualColumns = $this->virtualColumns; foreach ($virtualColumns as $key => $virtualColumn) { $result[$key] = $virtualColumn; } if ($includeForeignObjects) { if (null !== $this->aCategories) { switch ($keyType) { case TableMap::TYPE_CAMELNAME: $key = 'categories'; break; case TableMap::TYPE_FIELDNAME: $key = 'Categories'; break; default: $key = 'Categories'; } $result[$key] = $this->aCategories->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } if (null !== $this->aSubcategories) { switch ($keyType) { case TableMap::TYPE_CAMELNAME: $key = 'subcategories'; break; case TableMap::TYPE_FIELDNAME: $key = 'SubCategories'; break; default: $key = 'Subcategories'; } $result[$key] = $this->aSubcategories->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } if (null !== $this->aUser) { switch ($keyType) { case TableMap::TYPE_CAMELNAME: $key = 'user'; break; case TableMap::TYPE_FIELDNAME: $key = 'User'; break; default: $key = 'User'; } $result[$key] = $this->aUser->toArray($keyType, $includeLazyLoadColumns, $alreadyDumpedObjects, true); } } return $result; }