Foros del Web » Programando para Internet » PHP »

Selección a tablas de BD

Estas en el tema de Selección a tablas de BD en el foro de PHP en Foros del Web. Hola, a ver si alguno puede ayudarme. Estoy iniciándome en estoy y aún no tengo mucha idea. Estoy haciendo un buscador. Tengo un formulario con ...
  #1 (permalink)  
Antiguo 11/03/2012, 14:08
 
Fecha de Ingreso: agosto-2008
Mensajes: 13
Antigüedad: 11 años, 4 meses
Puntos: 0
Selección a tablas de BD

Hola, a ver si alguno puede ayudarme. Estoy iniciándome en estoy y aún no tengo mucha idea.

Estoy haciendo un buscador. Tengo un formulario con una serie de campos para hacer las búsquedas a la base de datos.

Hasta ahí todo bien...Si yo introduzco datos en los campos de textos y le doy a buscar, me devuelve los registros que coincidan con los campos introducidos

Lo que quiero es que si el campo va en blanco, me devuelva todos los registros de la base de datos.

Quiero saber si hay alguna solución que no sea:

if (empty(variable)){ ....una select sin where....}
else {....otra select con where campo = variable}

¿Cómo podría hacerlo?

Gracias y saludos.
  #2 (permalink)  
Antiguo 11/03/2012, 21:55
Avatar de xxxivanxxx  
Fecha de Ingreso: julio-2010
Ubicación: /home
Mensajes: 114
Antigüedad: 9 años, 4 meses
Puntos: 21
Respuesta: Selección a tablas de BD

bueno, si te molesta repetir las lineas de codigo, puedes hacer esto, aunque es lo mismo :)


Código PHP:
Ver original
  1. $sql="SELECT * from tabla ".(!empty($var)?"WHERE campo LIKE '".$var."'":"");
  #3 (permalink)  
Antiguo 11/03/2012, 23:59
Avatar de kSebaPerez  
Fecha de Ingreso: marzo-2012
Mensajes: 12
Antigüedad: 7 años, 8 meses
Puntos: 2
Respuesta: Selección a tablas de BD

mmm...


$query = "SELECT * FROM tabla";
if($var) { $query .= " WHERE=..."; }
mysql_query($query, $link);



Es lo unico que se me ocurre, anidarle al final un trozo mas de string en caso de que exista determinada variable.

Etiquetas: bd, formulario, registro, tablas
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 07:01.