Foros del Web » Programando para Internet » PHP »

Como ordenar mis usuarios

Estas en el tema de Como ordenar mis usuarios en el foro de PHP en Foros del Web. Hola amigos tengo un problema muy grande resulta qeu estoy haciendo una aplicación que su fin es subir banners a una web, la tabla de ...
  #1 (permalink)  
Antiguo 11/03/2009, 13:11
 
Fecha de Ingreso: febrero-2008
Mensajes: 72
Antigüedad: 16 años, 2 meses
Puntos: 0
Como ordenar mis usuarios

Hola amigos tengo un problema muy grande resulta qeu estoy haciendo una aplicación que su fin es subir banners a una web, la tabla de dichos banners contiene un campo llamado orden que sierve para mostrarme los banners en el orden que le indique 1,2,3,4,etc.


el problema es cuado tengo mi listado de banners lo que deceo es poder cambiar el orden de los banners.


pero no se como hacerle que si el 3 quiero que sea el 2 y que automaticamente se reacomoden todos los demas. he intentado muchas cosas y no me queda o se me repiten los campos de orden o simplemente no me da

ayudenme por favor.

para insertarlos no hay problema, el problema es al querer cambiar el orden en mio listado.

les dejo un poco de código para que lo vean porfavor


Código PHP:

        $__encuentra_orden 
mysql_query("select * from banners Order by orden asc");
        
    
        while(
$_ord mysql_fetch_array($__encuentra_orden))
        {
            if(
$_GET['orden'] == $_ord['orden'] && $_GET['id_b'] == $_ord['id']){
                
                    
$_new_ord[] = 'nuevo';
                
            }else if(
$_GET['orden'] != $_ord['orden'] && $_GET['id_b'] != $_ord['id']){
                
                
$_new_ord[] = 'nuevo';
                
$_new_ord[] = $_ord['id'];
                
            }else if(
$_GET['orden'] == $_ord['orden'] && $_GET['id_b'] != $_ord['id']){
                
$_new_ord[] = $_GET['id_b'];
                
$_new_ord[] = $_ord['id'];
            
            }else if(
$_GET['orden'] != $_ord['orden'] && $_GET['id_b'] == $_ord['id']){
                
                
mysql_query("Update banners set orden = '".$_GET['orden']."' Where id = '".$_GET['id_b']."' ");
                
#$_new_ord[] = $_ord['id'];                
            
}
            
        }
        
        
print_r($_new_ord);
        
        while(list(
$key$val) = each($_new_ord))
        {
            
            if(
$val != 'nuevo'){
                
                
mysql_query("Update banners set orden = '".($key+1)."' Where id = '".$val."' ");
            }
        } 
  #2 (permalink)  
Antiguo 11/03/2009, 13:19
 
Fecha de Ingreso: junio-2008
Ubicación: Capital Federal xD
Mensajes: 1.208
Antigüedad: 15 años, 10 meses
Puntos: 35
Respuesta: Como ordenar mis usuarios

porque no mejor que se muestren al azar?
Sin necesidad que tu los reordenes, en sql pon:
ORDER BY RAND()
y listo
  #3 (permalink)  
Antiguo 11/03/2009, 13:23
 
Fecha de Ingreso: febrero-2008
Mensajes: 72
Antigüedad: 16 años, 2 meses
Puntos: 0
Respuesta: Como ordenar mis usuarios

por que pidieron el proyecto de esa manera
  #4 (permalink)  
Antiguo 11/03/2009, 13:43
 
Fecha de Ingreso: junio-2008
Ubicación: Capital Federal xD
Mensajes: 1.208
Antigüedad: 15 años, 10 meses
Puntos: 35
Respuesta: Como ordenar mis usuarios

mmmmhhh pero si debes cambiar el 3º al 2º, solo afectaria a estos 2 registros, no?
Entonces el update lo hace entre esos 2 registros a traves de sus id:
primero capturas temporalmente el orden del 3º registro
$aux=$baner3[orden];
luego le actualizas su orden, pasará a orden igual a 2 ($_post[nuevo])
update banners set orden=$_post[nuevo] where id $_idBaner3
luego en el registro que tenia el 2º lugar lo pasas al orden que tenia el registro 3:
update banners set orden=$aux where id $_idBaner2

Entendiste porque ya me maree
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 23:49.