Foros del Web » Programando para Internet » PHP »

Instancia de Objetos con relaciones

Estas en el tema de Instancia de Objetos con relaciones en el foro de PHP en Foros del Web. Buenas Tardes amigos, En esta oportunidad quiero mostrarles un codigo que tengo para que me den su opinión al respecto. Preambulo : Estoy trabajando en ...
  #1 (permalink)  
Antiguo 22/03/2015, 18:24
 
Fecha de Ingreso: marzo-2011
Ubicación: Caracas
Mensajes: 389
Antigüedad: 13 años, 1 mes
Puntos: 16
Instancia de Objetos con relaciones

Buenas Tardes amigos,

En esta oportunidad quiero mostrarles un codigo que tengo para que me den su opinión al respecto.

Preambulo : Estoy trabajando en MVC, al instanciar un objeto y pasarle un id el mismo es instanciado, todo esto sin problemas. ahora la cuestión son aquellos campos cuyo valor es una relación o id. Para ello, sigo el estandard de que todos sean llamados "id_nombreRelacion" de modo que puedo identificar los campos de relacion y objetos, todos los objetos tienen unas propiedades "tablaBD y pk" para identificar las tablas en caso de que los nombres fuesen distintos a los objetos.

Ahora el metodo de consulta es el siguiente :

Código PHP:
Ver original
  1. function consulta($campos=""){
  2.         $banderaJoin = FALSE;
  3.         $join="";
  4.        
  5.        
  6.         if(empty($campos)){
  7.            
  8.             if(count($this->pertenece)>0){
  9.                 $camposJoin = "";
  10.                 $i=0;
  11.                
  12.                 foreach ($this->pertenece as $campo => $object) {
  13.                     $banderaJoin=TRUE;
  14.                     $tabla = "";
  15.                     $pk="";
  16.                     if(property_exists($object, 'tablaBD')){
  17.                        
  18.                         $tabla = $object->__get('tablaBD');
  19.                         $pk = $object->__get('pk');
  20.                         $props= $object->__get('propiedades');
  21.                        
  22.                     }elseif(property_exists($object, 'nombreTabla')){
  23.                         $tabla = $object->__get('nombreTabla');
  24.                         $pk = $object->__get('pk');
  25.                         $props = $object->__get('propiedadesPublicas');
  26.                     }//fin if
  27.                         $camposTabla = array_keys($props);
  28.                         array_walk($camposTabla,function(&$ele,$clave,$tabla){
  29.                                                         $ele = $tabla.".".$ele;
  30.                                         },$tabla);
  31.                         if($i>0)
  32.                             $camposJoin.=",";
  33.                         $camposJoin .=" ".implode(", ",$camposTabla);
  34.                     if(!empty($tabla) and !empty($pk)){
  35.                         $join .= sprintf(" LEFT JOIN %s on (%s.%s = %s.%s)",$tabla,$this->tablaBD,$pk,$tabla,$pk);
  36.                     }
  37.                     ++$i;
  38.                 }//foreach
  39.             }//fin if para joins
  40.         }
  41.         if(empty($campos)){
  42.             $campos =  array_keys($this->propiedades);
  43.         }
  44.        
  45.         if(is_array($campos)){
  46.             array_walk($campos,function(&$key,$valor,$tabla){
  47.                              $key=$tabla.".".$key;
  48.             },$this->tablaBD);
  49.        
  50.             $campos = implode(", ",$campos);
  51.         }
  52.        
  53.         $this->query="SELECT $campos ";
  54.         if($banderaJoin===TRUE)
  55.             $this->query .=", ".$camposJoin;
  56.         $this->query.=" from $this->tablaBD ".$join;
  57.         $this->usoWhere=FALSE;
  58.         return $this;
  59.     }


Ese metodo no ejecuta el query solo lo arma, luego hay un metodo que se encarga de la ejecución, la cuestión o duda que tengo en general es. ¿consideran que esto puede hacer lento las consultas? Yo lo ví como una solución al hecho de por ejemplo consultar una tabla que tenga un campo "estatus" y se quiera mostrar el texto del estatus y para ello tener que hacer una segunda consulta, con esto se evita ese tipo de problemas.
__________________
Lo imposible es lo posible visto por los ojos de un incapaz.
Si te sirve la respuesta. dale + al karma.
Saludos

Etiquetas: mvc, poo
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 11:29.