Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Array de objetos sobrescribe los datos anteriores!!

Estas en el tema de Array de objetos sobrescribe los datos anteriores!! en el foro de PHP en Foros del Web. Hola buenas, Hace poco que he empezado a programar en php, y aún no domino mucho el tema de los arrays, tengo un objeto productUnit ...
  #1 (permalink)  
Antiguo 21/02/2014, 05:35
 
Fecha de Ingreso: febrero-2014
Mensajes: 2
Antigüedad: 10 años, 2 meses
Puntos: 0
Pregunta Array de objetos sobrescribe los datos anteriores!!

Hola buenas,

Hace poco que he empezado a programar en php, y aún no domino mucho el tema de los arrays, tengo un objeto productUnit con sus getters i setters, aquí lo muestro:

Código:
   class productUnit{
   	var $id;
	var $serial_number;
	var $stock_id;
	var $years_warranty;
	var $rental_price;
	var $purchase_price;
	var $purchase_date;
	var $product_box_id;
	var $product_template_id;
	var $closet_id;
	
	/**
	 * funcions per carregar valors a l'objecte(setters)
	 */
	
	function setId($id){
		$this->id=$id;
	}
	
	function setSerial($serial){
		$this->serial_number = $serial;
	}
	
	function setStock($stock){
		$this->stock_id = $stock;
	}
	
	function setWarranty($years){
		$this->years_warranty = $years;
	}
	
	function setRentalPrice($price){
		$this->rental_price = $price;
	}
	
	function setPurchasePrice($price){
		$this->purchase_price = $price;
	}
	
	function setPurchaseDate($date){
		$this->purchase_date = $date;
	}
	
	function setProductBox($id_box){
		$this->product_box_id=$id_box;
	}
	
	function setProductTemplate($id_template){
		$this->product_template_id = $id_template;
	}
	
	function setCloset($id_closet){
		$this->closet_id = $id_closet;
	}
	
	
	/**
	 * funcions per retornar valors desde l'objecte(getters)
	 */
	
	function getId(){
		return $this->id;
	}
	
	function getSerial(){
		return $this->serial_number;
	}
	
	function getStock(){
		return $this->stock_id ;
	}
	
	function getWarranty(){
		return $this->years_warranty ;
	}
	
	function getRentalPrice(){
	 	return $this->rental_price;
	}
	
	function getPurchasePrice(){
		return $this->purchase_price;
	}
	
	function getPurchaseDate(){
		return $this->purchase_date;
	}
	
	function getProductBox(){
		return $this->product_box_id;
	}
	
	function getProductTemplate(){
		return $this->product_template_id;
	}
	
	function getCloset(){
		return $this->closet_id;
	}
	
	
   }
Entonces también tengo en la base de datos una tabla que comparte los mismos campos que su objeto correspondiente, y mi problema viene al recuperar los datos de esta y asignarlos a un array de objetos, para hacerlo uso la siguiente función:

Código:
function getAllProducts() {
	global $connexio;
	$product = new productUnit();
	$query = "SELECT * FROM product_unit;";
	$result = mysqli_query($connexio, $query);
	$i = 0;
	$products = array();
	while ($row = mysqli_fetch_row($result)) {
		
		$product -> setId($row[0]);
		$product -> setSerial($row[1]);
		$product -> setStock($row[2]);
		$product -> setWarranty($row[3]);
		$product -> setRentalPrice($row[4]);
		$product -> setPurchasePrice($row[5]);
		$product -> setPurchaseDate($row[6]);
		$product -> setProductBox($row[7]);
		$product -> setProductTemplate($row[8]);
		$product -> setCloset($row[9]);
		$products[$i] = $product;
		$i++;
		
	}

	
	return $products;
}
Y mi sorpresa es que luego al realizar el muestreo del array me muestra siempre el último producto del array, haciendo algunos alerts dentro de la función he descubierto que durante cada vuelta del while los datos se asignan como debería ser, pero extrañamente después cuándo termina el while i observo el array creado me doy cuenta de que los datos se han sobrescrito y que en todas las posiciones del array está el mismo objeto, el último que devuelve la consulta.

A alguien se le ocurre porqué ocurre esto??

Gracias de antemano!!
  #2 (permalink)  
Antiguo 21/02/2014, 05:45
Avatar de Tokkara  
Fecha de Ingreso: junio-2008
Mensajes: 131
Antigüedad: 15 años, 10 meses
Puntos: 5
Respuesta: Array de objetos sobrescribe los datos anteriores!!

Eso se debe a que solo creas un objeto de la clase productUnit. Tienes que crear un objeto por cada fila de la tabla. Básicamente estás guardando el mismo objeto en cada celda del array y remplazando sus datos una y otra vez. Prueba así.
Código PHP:
Ver original
  1. function getAllProducts() {
  2.     global $connexio;
  3.    
  4.     $query = "SELECT * FROM product_unit;";
  5.     $result = mysqli_query($connexio, $query);
  6.     $i = 0;
  7.     $products = array();
  8.     while ($row = mysqli_fetch_row($result)) {
  9.         $product = new productUnit();
  10.  
  11.         $product -> setId($row[0]);
  12.         $product -> setSerial($row[1]);
  13.         $product -> setStock($row[2]);
  14.         $product -> setWarranty($row[3]);
  15.         $product -> setRentalPrice($row[4]);
  16.         $product -> setPurchasePrice($row[5]);
  17.         $product -> setPurchaseDate($row[6]);
  18.         $product -> setProductBox($row[7]);
  19.         $product -> setProductTemplate($row[8]);
  20.         $product -> setCloset($row[9]);
  21.         $products[$i] = $product;
  22.         $i++;
  23.        
  24.     }
  25.  
  26.    
  27.     return $products;
  28. }

Ahora se crea en la variable $product un objeto nuevo por cada vuelta al bucle. Y por tanto en el array se guardará un objeto distinto cada vez.
__________________
Revolucionario controlador de plantillas para php
www.simphple.com
  #3 (permalink)  
Antiguo 21/02/2014, 05:49
 
Fecha de Ingreso: febrero-2014
Mensajes: 2
Antigüedad: 10 años, 2 meses
Puntos: 0
Respuesta: Array de objetos sobrescribe los datos anteriores!!

Genial muchísimas gracias!! Ahora funciona perfecto!

Etiquetas: mysql, objetos, select, tabla
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 09:16.