Optimizacion de obtencion de datos.
This commit is contained in:
@ -11,7 +11,9 @@ use Incoviba\Service;
|
||||
|
||||
class Propiedad extends Ideal\Repository
|
||||
{
|
||||
public function __construct(Define\Connection $connection, protected Service\Venta\PropiedadUnidad $propiedadUnidadService, protected Service\Venta\Unidad $unidadService)
|
||||
public function __construct(Define\Connection $connection,
|
||||
protected Service\Venta\PropiedadUnidad $propiedadUnidadService,
|
||||
protected Service\Venta\Unidad $unidadService)
|
||||
{
|
||||
parent::__construct($connection);
|
||||
$this->setTable('propiedad');
|
||||
@ -71,4 +73,21 @@ class Propiedad extends Ideal\Repository
|
||||
->where('`unidad_principal` = ? AND `estado` = 1');
|
||||
return $this->fetchOne($query, [$unidad_id]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $propiedad_id
|
||||
* @return array
|
||||
* @throws Implement\Exception\EmptyResult
|
||||
*/
|
||||
public function fetchArrayById(int $propiedad_id): array
|
||||
{
|
||||
$query = $this->connection->getQueryBuilder()
|
||||
->select()
|
||||
->from($this->getTable())
|
||||
->where('`id` = ?')
|
||||
->limit(1);
|
||||
$propiedad = $this->fetchAsArray($query, [$propiedad_id])[0];
|
||||
$propiedad['unidades'] = $this->propiedadUnidadService->getArrayByPropiedad($propiedad_id);
|
||||
return $propiedad;
|
||||
}
|
||||
}
|
||||
|
@ -104,6 +104,26 @@ class PropiedadUnidad extends Ideal\Repository
|
||||
return $this->fetchMany($query, [$propiedad_id]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $propiedad_id
|
||||
* @return array
|
||||
* @throws Implement\Exception\EmptyResult
|
||||
*/
|
||||
public function fetchArrayByPropiedad(int $propiedad_id): array
|
||||
{
|
||||
$query = $this->connection->getQueryBuilder()
|
||||
->select('a.id AS pu_id, a.valor, a.propiedad, unidad.*')
|
||||
->from("{$this->getTable()} a")
|
||||
->joined('INNER JOIN `unidad` ON a.`unidad` = `unidad`.`id`')
|
||||
->where('a.`propiedad` = ?')
|
||||
->group('`unidad`.`id`');
|
||||
$unidades = $this->fetchAsArray($query, [$propiedad_id]);
|
||||
array_walk($unidades, function(&$unidad) {
|
||||
$unidad['proyecto_tipo_unidad'] = json_decode(json_encode($this->proyectoTipoUnidadService->getById($unidad['pt'])), true);
|
||||
});
|
||||
return $unidades;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param Define\Model $model
|
||||
* @return void
|
||||
|
@ -44,7 +44,7 @@ class Propiedad extends Service
|
||||
public function getArrayById(int $propiedad_id): array
|
||||
{
|
||||
try {
|
||||
return json_decode(json_encode($this->propiedadRepository->fetchById($propiedad_id)), true);
|
||||
return $this->propiedadRepository->fetchArrayById($propiedad_id);
|
||||
} catch (EmptyResult $exception) {
|
||||
throw new Exception\ServiceAction\Read(__CLASS__, $exception);
|
||||
}
|
||||
|
@ -42,6 +42,14 @@ class PropiedadUnidad
|
||||
return [];
|
||||
}
|
||||
}
|
||||
public function getArrayByPropiedad(int $propiedad_id): array
|
||||
{
|
||||
try {
|
||||
return $this->propiedadUnidadRepository->fetchArrayByPropiedad($propiedad_id);
|
||||
} catch (EmptyResult) {
|
||||
return [];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array $data
|
||||
|
Reference in New Issue
Block a user