Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Si un campo esta lleno pasar al siguiente

Estas en el tema de Si un campo esta lleno pasar al siguiente en el foro de PHP en Foros del Web. Hola y de antemano gracias por su tiempo Tengo una base de datos de una biblioteca con la tabla libro y la tabla Usuarios con ...
  #1 (permalink)  
Antiguo 26/07/2015, 10:49
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Si un campo esta lleno pasar al siguiente

Hola y de antemano gracias por su tiempo

Tengo una base de datos de una biblioteca con la tabla libro y la tabla Usuarios con los siguientes campos:

Usuarios
id
nombre
libro1
libro2
libro3

Libros:
codigo
Titulo
Autor

Quiero que cuando un libro este en prestamo para un usuario pase a ocupar el campo libro1 pero que si ya esta ocupado ocupe el libro2 y si los tres campos libro1, libro2 y libro3 estan ocupados mande un mensaje diciendo que ha superado el limite de prestamos permitidos pero no se como indicar que si un campo ya tiene datos pase al siguiente.

Muchas gracias
  #2 (permalink)  
Antiguo 26/07/2015, 12:00
Avatar de xfxstudios  
Fecha de Ingreso: junio-2015
Ubicación: Valencia - Venezuela
Mensajes: 2.448
Antigüedad: 9 años, 4 meses
Puntos: 263
Respuesta: Si un campo esta lleno pasar al siguiente

lo que deberias hacer es poner un limite de registros duplicados en la tabla y no lo que estas intentando hacer, asi cuando se intente superar ese limite el sistema emita una alerta, tambien poner una validacion en un if al momento de buscar al usuario y que si este tiene 3 registros en la base indique que ya no puede sacar mas libros hasta regresar alguno de los otros
__________________
[email protected]
HITCEL
  #3 (permalink)  
Antiguo 26/07/2015, 12:05
Avatar de MaNuX0218  
Fecha de Ingreso: marzo-2014
Mensajes: 787
Antigüedad: 10 años, 8 meses
Puntos: 67
Respuesta: Si un campo esta lleno pasar al siguiente

Si nos pasaras el código sería más facil de ayudarte, pero mas o menos podrias hacer:

Supongamos que ya has realizado la consulta para sacar todos los registros. Solo te quedaria comprobar si estan vacios o no:

Código PHP:
Ver original
  1. if(empty($row['libro1']){
  2.    // este caso libro uno no hay nada, entonces se lo asignamos...
  3. }else{
  4.    if(empty($row['libro2'])){
  5.       // aqui le asignamos al libro2 2 ya que no está vacio libro1...
  6.    }else{
  7.       if(empty($row['libro3'])){
  8.          // aqui le asignamos el ultimo (libro3), que anteriormente hemos comprobado que libro1 y libro2 no estan vacios...
  9.       }else{
  10.          // aqui ya pasamos a que libro1, libro2 y libro3 no estan vacios, con lo que puedes informarles de que han superado el limite, etc...
  11.       }
  12.    }
  13. }

Espero que se entienda, cualquier duda comenta, aun que esto es una posibilidad hay miles de formas de hacerlo y como te comentado si muestras el código nos será más facil.

Un saludo.
__________________
No te preocupes si tu código no funciona bien. Si todo lo hiciera, no tendrías trabajo.
  #4 (permalink)  
Antiguo 26/07/2015, 12:10
Avatar de xfxstudios  
Fecha de Ingreso: junio-2015
Ubicación: Valencia - Venezuela
Mensajes: 2.448
Antigüedad: 9 años, 4 meses
Puntos: 263
Respuesta: Si un campo esta lleno pasar al siguiente

es mejor utilizar una columna para el libro y validar cuantos prestamos tiene el usuario:
Código PHP:
Ver original
  1. <?php
  2.  
  3. $busca = $db->query("SELECT * FROM usuarios WHERE nombre = '$loquesea'");
  4. $total = mysqli_num_rows($busca);
  5. //validamos si tiene 3 libros prestados
  6. if($total ==3){
  7.     echo "El usuario supero el limite de retiros";
  8.     //listamos los libros prestados
  9.     while($row = $busca->fetch_array())
  10.         {
  11.             echo "Libro prestado: ".$row['libro']."<br>";
  12.         }
  13.  
  14. //en caso de tener 2 o menos prestamos
  15. } else if($total <=2){
  16.    
  17.     echo "El usuario tiene disponibles: ".(3-$total). "libros para prestamos";
  18. }
  19.  
  20. ?>
__________________
[email protected]
HITCEL
  #5 (permalink)  
Antiguo 26/07/2015, 13:09
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 16 años, 3 meses
Puntos: 2237
Respuesta: Si un campo esta lleno pasar al siguiente

Qué pasa si un día te piden que en lugar de 3 libros el usuario pueda tener 10?

Con tu lógica actual, si el usuario devuelve "libro1", tendrás que recorrer los códigos de "libro2" y "libro3" para ocupar las posiciones anteriores y no conservas registro de cuándo fueron prestados y devueltos los libros.

La mejor opción es tener otra tabla donde tengas un registro de libros que has prestado al usuario:

Código:
id_usuario
codigo_libro
fecha_prestado
fecha_devuelto -> Este valor será nulo hasta que se devuelva el libro
Consultas esta tabla, contando los libros del usuario donde fecha_devuelto sea nulo, si ya le prestaste 3 muestras el mensaje; si no, entonces solo agregas el nuevo registro.

La consulta sería algo como:

Código MySQL:
Ver original
  1. SELECT COUNT(*) FROM libros_prestados WHERE id_usuario = aqui_la_id_del_usuario AND fecha_devuelto = NULL
__________________
- León, Guanajuato
- GV-Foto

Última edición por Triby; 26/07/2015 a las 13:10 Razón: Corregir consulta
  #6 (permalink)  
Antiguo 26/07/2015, 14:49
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

esto es lo que estoy haciendo para ingresar datos en libro1 pero como pondrialo otro?

mysql_query("UPDATE usuario set libro1 ='$libro1' WHERE id ='$id'");
  #7 (permalink)  
Antiguo 26/07/2015, 14:54
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

Mira puse el codigo asi

if(empty($row['libro1']){
mysql_query("UPDATE usuario set libro1 ='$libro1' WHERE id ='$id'");
}else{
if(empty($row['libro2'])){
mysql_query("UPDATE usuario set libro2 ='$libro1' WHERE id ='$id'");
}else{
if(empty($row['libro3'])){
mysql_query("UPDATE usuario set libro3 ='$libro1' WHERE id ='$id'");
}else{
Lo sentimos el usuario ha superado el limite de retiros posibles.
}
}
}

pero me sale error unexpected { en el primer if
  #8 (permalink)  
Antiguo 26/07/2015, 15:02
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

Cita:
Iniciado por MaNuX0218 Ver Mensaje
Si nos pasaras el código sería más facil de ayudarte, pero mas o menos podrias hacer:

Supongamos que ya has realizado la consulta para sacar todos los registros. Solo te quedaria comprobar si estan vacios o no:

Código PHP:
Ver original
  1. if(empty($row['libro1']){
  2.    // este caso libro uno no hay nada, entonces se lo asignamos...
  3. }else{
  4.    if(empty($row['libro2'])){
  5.       // aqui le asignamos al libro2 2 ya que no está vacio libro1...
  6.    }else{
  7.       if(empty($row['libro3'])){
  8.          // aqui le asignamos el ultimo (libro3), que anteriormente hemos comprobado que libro1 y libro2 no estan vacios...
  9.       }else{
  10.          // aqui ya pasamos a que libro1, libro2 y libro3 no estan vacios, con lo que puedes informarles de que han superado el limite, etc...
  11.       }
  12.    }
  13. }

Espero que se entienda, cualquier duda comenta, aun que esto es una posibilidad hay miles de formas de hacerlo y como te comentado si muestras el código nos será más facil.

Un saludo.


Ya amigo muchas gracias me sirvió tu aporte gracias a todos los que me ayudaron
  #9 (permalink)  
Antiguo 26/07/2015, 16:27
 
Fecha de Ingreso: junio-2014
Mensajes: 3
Antigüedad: 10 años, 5 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

Si simplificas un poco arto el código este quedaría así:

Código PHP:
Ver original
  1. <?php
  2.        if($row['linea'] < 4) { 'Usted si puede sacar más libros' }
  3.             else {'Usted ha superado el número de libros'}
  4. ?>


y en la consulta das el parámetro de orden

Código PHP:
Ver original
  1. Order BY id_contador where disponibilidad = 'disponible'
  #10 (permalink)  
Antiguo 26/07/2015, 17:10
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

Cita:
Iniciado por MaNuX0218 Ver Mensaje
Si nos pasaras el código sería más facil de ayudarte, pero mas o menos podrias hacer:

Supongamos que ya has realizado la consulta para sacar todos los registros. Solo te quedaria comprobar si estan vacios o no:

Código PHP:
Ver original
  1. if(empty($row['libro1']){
  2.    // este caso libro uno no hay nada, entonces se lo asignamos...
  3. }else{
  4.    if(empty($row['libro2'])){
  5.       // aqui le asignamos al libro2 2 ya que no está vacio libro1...
  6.    }else{
  7.       if(empty($row['libro3'])){
  8.          // aqui le asignamos el ultimo (libro3), que anteriormente hemos comprobado que libro1 y libro2 no estan vacios...
  9.       }else{
  10.          // aqui ya pasamos a que libro1, libro2 y libro3 no estan vacios, con lo que puedes informarles de que han superado el limite, etc...
  11.       }
  12.    }
  13. }

Espero que se entienda, cualquier duda comenta, aun que esto es una posibilidad hay miles de formas de hacerlo y como te comentado si muestras el código nos será más facil.

Un saludo.
Disculpen ahora tengo otro problema, si ya aparece que hice la devolucion quisiera que ese campo quedara vacio pero no se como lograrlo

Código PHP:
Ver original
  1. if($row['libro1'] = "$codigo1"){
  2.        mysql_query("UPDATE usuario set libro1 = '$libro1' WHERE id ='$idant'");
  3.        echo "La edición se realizó correctamente, será redireccionado pronto";
  4.     }else{
  5.        if($row['libro2'] = "$codigo1"){
  6.           mysql_query("UPDATE usuario set libro2 = NULL WHERE id ='$id'");
  7.           echo "La edición se realizó correctamente, será redireccionado pronto";
  8.        }else{
  9.           if($row['libro3'] = "$codigo1"){
  10.              mysql_query("UPDATE usuario set libro3 = '$libro1' WHERE id ='$id'");
  11.              echo "La edición se realizó correctamente, será redireccionado pronto";
  12.           }else{
  13.              echo "Lo sentimos el usuario ha superado el limite de retiros posibles.";
  14.           }
  15.        }
  16.     }
  #11 (permalink)  
Antiguo 26/07/2015, 19:06
 
Fecha de Ingreso: julio-2015
Ubicación: Pereira, Risaralda
Mensajes: 18
Antigüedad: 9 años, 3 meses
Puntos: 0
Respuesta: Si un campo esta lleno pasar al siguiente

Cita:
Iniciado por Triby Ver Mensaje
Qué pasa si un día te piden que en lugar de 3 libros el usuario pueda tener 10?

Con tu lógica actual, si el usuario devuelve "libro1", tendrás que recorrer los códigos de "libro2" y "libro3" para ocupar las posiciones anteriores y no conservas registro de cuándo fueron prestados y devueltos los libros.

La mejor opción es tener otra tabla donde tengas un registro de libros que has prestado al usuario:

Código:
id_usuario
codigo_libro
fecha_prestado
fecha_devuelto -> Este valor será nulo hasta que se devuelva el libro
Consultas esta tabla, contando los libros del usuario donde fecha_devuelto sea nulo, si ya le prestaste 3 muestras el mensaje; si no, entonces solo agregas el nuevo registro.

La consulta sería algo como:

Código MySQL:
Ver original
  1. SELECT COUNT(*) FROM libros_prestados WHERE id_usuario = aqui_la_id_del_usuario AND fecha_devuelto = NULL
y como seria el codigo para decir que ya lo devolvió? gracias
  #12 (permalink)  
Antiguo 27/07/2015, 09:22
Avatar de Triby
Mod on free time
 
Fecha de Ingreso: agosto-2008
Ubicación: $MX->Gto['León'];
Mensajes: 10.106
Antigüedad: 16 años, 3 meses
Puntos: 2237
Respuesta: Si un campo esta lleno pasar al siguiente

Sencillo, solo actualizas el registro para asignar la fecha de devolución.
__________________
- León, Guanajuato
- GV-Foto

Etiquetas: campo, lleno, siguiente, tabla, usuarios
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:09.