funcion recursiva de hijo a padre

Iniciado por satan69, 22 Octubre 2010, 00:22 AM

0 Miembros y 1 Visitante están viendo este tema.

satan69

function url_pagina_categoria($link,$hija,$x){
    
$sql="SELECT * FROM `contenido` WHERE idcontenido = ".$hija;
    
$result=mysql_query($sql);
if(
$result){
    
$row mysql_fetch_array($result);
$nombre $row['nombre'];
$idcontenido $row['idcontenido'];
$parent $row['parent'];
if(
$x==''){
$x=0;
}
if(
$parent==0){
$nombre str_replace(' ','-',$nombre); 
$link[$x] = $nombre.$x;
    }else{
$x $x+1;
$nombre str_replace(' ','-',$nombre); 
$link[$x]=$nombre;
url_pagina_categoria($link,$parent,$x);
}
}
//fin del la funcion revisar si existen datos
return $link;
}


tonces en teorioa yo tendria que hacer esto

$link =url_pagina_categoria($link,3,$x)
aqui necesito que me regrese un array donde con el codigo que tengo de ordenar o tambien puedo usar el que tu me diste, lo ordeno y creo :


Foro de elhacker.net
|-+  Programación
| |-+  Desarrollo Web
| | |-+  PHP

Programación
id  1
parent 0

Desarrollo Web
id   2
parent 1

PHP
id 3
parent 2

~ Yoya ~

Te sale solo uno porque usas if y necesitas que el ciclo se vaya repitiendo...


Código (php) [Seleccionar]
<?php 

$connect 
mysql_connect('127.0.0.1''root''password');
mysql_select_db('ejemplo'$connect);

$sql mysql_query('select id from ejemplo');

while(
$row mysql_fetch_array($sqlMYSQL_NUM))
   {
      
print_r($row);
   }

 
?>


Salida:
Array
(
    [0] => 1
)
Array
(
    [0] => 2
)
Array
(
    [0] => 3
)


Con if
Código (php) [Seleccionar]
<?php 

$connect 
mysql_connect('127.0.0.1''root''pass');
mysql_select_db('ejemplo'$connect);

$sql mysql_query('select id from ejemplo');

if(
$row mysql_fetch_array($sqlMYSQL_NUM))
   {
      
print_r($row);
   }

 
?>


Salida:
Código (php) [Seleccionar]
Array
(
    [0] => 1
)



Creo que también tienes un error con el array, aqui un ejemplo:
Código (php) [Seleccionar]
<?php 

$array
[] = 'asa';
$array[] = 5656;
$array[] = 1515.545;

print_r($array);

?>


Salida:

Array
(
    [0] => asa
    [1] => 5656
    [2] => 1515.545
)
Mi madre me dijo que estoy destinado a ser pobre toda la vida.
Engineering is the art of balancing the benefits and drawbacks of any approach.

satan69

#12
si te entiendo, pero utilizando funcion recursiva como la que te estaba ensenado..?

~ Yoya ~

Código (php) [Seleccionar]
<?php 

$connect 
mysql_connect('127.0.0.1''root''pass');
mysql_select_db('ejemplo'$connect);

function 
ejemplo_while($str){
$sql mysql_query($str);
while(
$row mysql_fetch_array($sqlMYSQL_NUM))
   {
      
$result[] = $row[0];
   }
   return 
$result;
}
 
$sql ejemplo_while('select id from ejemplo');
print_r($sql);

 
?>


Salida:

Array
(
    [0] => 1
    [1] => 2
    [2] => 3
)

Mi madre me dijo que estoy destinado a ser pobre toda la vida.
Engineering is the art of balancing the benefits and drawbacks of any approach.

satan69

Cita de: ~ Yoya ~ en 23 Octubre 2010, 18:23 PM
Código (php) [Seleccionar]
<?php 

$connect 
mysql_connect('127.0.0.1''root''pass');
mysql_select_db('ejemplo'$connect);

function 
ejemplo_while($str){
$sql mysql_query($str);
while(
$row mysql_fetch_array($sqlMYSQL_NUM))
   {
      
$result[] = $row[0];
   }
   return 
$result;
}
 
$sql ejemplo_while('select id from ejemplo');
print_r($sql);

 
?>


Salida:

Array
(
    [0] => 1
    [1] => 2
    [2] => 3
)




gracias por todos los mensajes, pero esa funcion no es recursiva, mira le ejemplo que te puse

id  1
Programación
parent 0


id  2
Desarrollo Web
parent 1


id 3
PHP
parent 2


ejemplo quiero sacar todos los padres de php? ese es el ejemplo

~ Yoya ~

Citarejemplo quiero sacar todos los padres de php? ese es el ejemplo
Cada vez entiendo menos tu problema... Ps en vez de crear un source que ya estoy perdido xD, mejor arreglemos tu source..

Citarmira la funcion que tengo, a simplevista uno cree que funciona pero no funciona porque no me guarda el arreglo link, cuando quiero imprimirlo con print_r sale solo el ultimo que entro en el arreglo, ahora si tiene mas de 5 padres deberia de salir los  5 no el ultimo, me entiendes..?

CitarTe sale solo uno porque usas if y necesitas que el ciclo se vaya repitiendo...
Mi madre me dijo que estoy destinado a ser pobre toda la vida.
Engineering is the art of balancing the benefits and drawbacks of any approach.

satan69

Cita de: ~ Yoya ~ en 23 Octubre 2010, 21:04 PM
Citarejemplo quiero sacar todos los padres de php? ese es el ejemplo
Cada vez entiendo menos tu problema... Ps en vez de crear un source que ya estoy perdido xD, mejor arreglemos tu source..

Citarmira la funcion que tengo, a simplevista uno cree que funciona pero no funciona porque no me guarda el arreglo link, cuando quiero imprimirlo con print_r sale solo el ultimo que entro en el arreglo, ahora si tiene mas de 5 padres deberia de salir los  5 no el ultimo, me entiendes..?

CitarTe sale solo uno porque usas if y necesitas que el ciclo se vaya repitiendo...


mira el primer mensaje que puse, lo que quiero yo es con esa funcion obtener todos los padres meterlos en un array despues ordenarlos...


saludos

~ Yoya ~

#17
puedes poner la estructura de la tabla que usas y algunos de los registro que tienen, así puedo testear...
Mi madre me dijo que estoy destinado a ser pobre toda la vida.
Engineering is the art of balancing the benefits and drawbacks of any approach.

Xt3mP

No se si te entendí muy bien pero lo que quieres hacer es que si la estructura es:
1 > 2 > 3 > 4 y quieres mostrar el 3 te muestre 1 > 2 > 3 o bien si quieres mostrar el 4 te muestre 1 > 2 > 3 > 4, es decir que si tienes digamos "3 categorías" y eliges la número 3, te cree como un árbol prácticamente desde la primer categoría hasta la que elegiste?
Citar1
|+2
|++3

Sí es así y es por base de datos (mis ocurrencias son grandes pero funcionan) primero tendría que saber como estan ordenadas tus tablas para ver como haré la petición, bueno, según leí tienes un id y un parent para indicar, entonces una posible solución sería:

La función que tienes para obtener el "ID" y ya sea un bucle (digamos, si el parent o el ID esta por orden númerico) que mientras el $i < ID_categoria te tire las anteriores, asi que suponiendo que tenemos
1 = ID 1
2 = ID 2
3 = ID 3

Si elegimos la 3 seria $i = 0 ; $i < 3; $i++ entonces de esta manera obtendras todos los ID anteriores o parents (según te acomodes), ya solo sería cuestión de que los organizes en un array y los muestres.

Ahora, si solo te tira el último, puedes utilizar array_push() con el nuevo padre para asi agregarlo al final ya que pues dicha función va agregando valores al final de un array, pero bueno, alomejor al leer esto te da ideas, saludos.