Sobrecarga en PHP 4.x

Una de las cosas que mas extraño a la hora de desarrollar en PHP es poder Sobrecargar métodos. Dado que PHP no lo soporta, al menos en sus versiones 4.x.

La sobrecarga es la habilidad que tienen muchos lenguajes OOP para poder definir varios métodos con el mismo nombre pero con diferentes números/tipos de parámetros. De esta manera se ejecuta uno u otro dependiendo la cantidad y los tipos de parámetros pasados.

Sin embargo podemos recurrir a un pequeño truco para poder sobrecargar métodos dependiendo el número de parámetros. La sobrecarga por tipos de datos no se puede hacer dado que no hay tipos de datos en PHP.


class MiClase  {

  function MiClase() {
    $nombre="MiClase".func_num_args();
    $this->$nombre();
  }

  function MiClase1($x) {
    //código;
  }

  function MiClase2($x,$y) {
    //código;
  }

}

De esta manera, con func_num_args() obtenemos el numero de parámetros pasados al constructor de MiClase, y en base a ese valor generamos el nombre de la función a llamar en $nombre. Fácil, no? ;)

Posted: March 26th, 2007 | Author: lichi | Filed under: development, php | Tags: , | No Comments »

EZ Results y Postgre

Desarrollando una aplicación PHP contra una DB Postgre, me encontré con un pequeño problema a la hora de hacer la paginación de resultados.
Dado que estoy usando la clase ezSQL para manipular la base de datos desde una capa abstraída, decidí, también, utilizar la clase de paginación EZ Results. Ambas creadas por JV Multimedia [1].
El problema es que esta clase no tiene soporte para Postgre, dado que el manejo de la clausula LIMIT es distinto a MySQL.
No hubo mucho de que preocuparse. Simplemente buscamos la linea donde se hace referencia al LIMIT de la consulta y la modificamos de la siguiente manera:

Original:
LIMIT {$_REQUEST['BRSR']},$this->num_results_per_page

Modificamos por:
OFFSET {$_REQUEST['BRSR']} LIMIT $this->num_results_per_page

Luego, desde el archivo donde queremos paginar nuestros resultados simplemente:

include_once “lib/ez_results.php”;
$ezr->query_mysql(“select campo1, campo2 from tabla”);
$ezr->display();

Fácil, ¿no? ;)

[1] http://www.woyano.com/jv/ezsql

Lisandro Grassini

Posted: March 9th, 2007 | Author: lichi | Filed under: development, php, postgre | Tags: , , | 1 Comment »