Retroceder   Foros del Web > Programación para sitios web > PHP

Respuesta
 
Herramientas Desplegado
Antiguo 12-may-2008, 01:39   #1 (permalink)
MartaMad ha deshabilitado el karma
 
Fecha de Ingreso: julio-2007
Mensajes: 34
Problema en select

Hola a tod@s,

A ver si me podéis echar un cable, tengo una tabla con datos de clientes... Quiero hacer una consulta desde un formulario php, en el que hay distintos campos de texto y unos checkbox, simplemente con marcar un checkbox y darle a Consultar valdría, no hace falta rellenar más de 1 campo....

Quiero hacer un select que me haga una consulta en la que me saque cada cliente que cumpla una de las condiciones (o todas) marcadas.... Es decir, si en el formulario escribo:


nombre -> Pepito

Pendiente (marcado)

Que me busque en la base de datos Pepito y marcado que cumplan esas condiciones... pero el problema está cuando sólo marco Pendiente, por ejemplo, y quiero que me saque todos los que están pendiente...

Hago la consulta así, pero no me sale bien el resultado, bueno no me sale nada.....

$condiciones = "FROM Clientes WHERE ";

if (isset($nombre)){$condiciones.= "nombre='".$nombre."'";}
if (isset($apellidos)){$condiciones.= " AND apellido1='".$apellidos."'";}
if (isset($domicilio)){$condiciones.= " AND calle='".$domicilio."'";}
if (isset($localidad)){$condiciones.= " AND ciudad='".$localidad."'";}
if (isset($cp)){$condiciones.= " AND cp='".$cp."'";}
if (isset($pais)){$condiciones.= " AND pais='".$pais."'";}
if (isset($telefono)){$condiciones.= " AND telefono='".$telefono."'";}
if (isset($movil)){$condiciones.= " AND movil='".$movil."'";}
if (isset($email)){$condiciones.= " AND email='".$email."'";}

if (isset($pendiente)){$condiciones.= " AND pendiente='".$pendiente."'";}
if (isset($devpaq)){$condiciones.= " AND devpaq='".$devpaq."'";}
if (isset($contacto)){$condiciones.= " AND contacto='".$contacto."'";}
if (isset($leidoguion)){$condiciones.= " AND leidoguion='".$leidoguion."'";}
if (isset($envpresen)){$condiciones.= " AND envpresen='".$envpresen."'";}
if (isset($distribuidor)){$condiciones.= " AND distribuidor='".$distribuidor."'";}
if (isset($compaq)){$condiciones.= " AND compaq='".$compaq."'";}
if (isset($diremal)){$condiciones.= " AND diremal='".$diremal."'";}
if (isset($pagadopaq)){$condiciones.= " AND pagadopaq='".$pagadopaq."'";}
if (isset($correomal)){$condiciones.= " AND correomal='".$correomal."'";}

$subquery = "SELECT * ".$condiciones;
$subresult=mysql_query($subquery);
$num_registros = mysql_num_rows($subresult);


Creo que con esté código si no viene vacío el campo pues añade la condición para que lo busque y si viene vacío no busca por ese campo.... Debería funcionar así, no?

Se os ocurre algo para solucionarlo??


Un saludo y gracias
MartaMad está desconectado   Responder Citando
Antiguo 12-may-2008, 04:45   #2 (permalink)
jurena tiene algunos puntos positivos de karma
 
Fecha de Ingreso: marzo-2008
Ubicación: Cáceres
Mensajes: 589
Re: Problema en select

El problema es realmente de PHP y te aconsejo buscar ayuda allí. No obstante, una sugerencia: cambia esto, para que haga siempre la búsqueda
$condiciones = "FROM Clientes WHERE 1 = 1 ";

if (isset($nombre)){$condiciones.= "AND nombre='".$nombre."'";}
jurena esta en línea ahora   Responder Citando
Antiguo 15-may-2008, 22:47   #3 (permalink)
Moderador NO Sabio
BrujoNic llegará a ser famoso muy prontoBrujoNic llegará a ser famoso muy prontoBrujoNic llegará a ser famoso muy prontoBrujoNic llegará a ser famoso muy prontoBrujoNic llegará a ser famoso muy pronto
 
Avatar de BrujoNic
 
Fecha de Ingreso: noviembre-2002
Ubicación: Costa Rica/Nicaragua
Mensajes: 10.899
Respuesta: Problema en select

Trasladado de BD a PHP. Favor no poner código de programación en BD.

Función de la sección de Base de Datos
__________________
Orgulloso de ser latino y demostrar que si uno trata de escribir bien, los demás comprenderán lo que respondo.
¿Fácil verdad?
BrujoNic está desconectado   Responder Citando
Respuesta
No hay votos aún.


Herramientas
Desplegado

Normas de Publicación
No puedes crear nuevos temas
No puedes responder temas
No puedes subir archivos adjuntos
No puedes editar tus mensajes

BB code is Activado
Caritas están Activado
[IMG] está Activado
Código HTML está Desactivado


La Zona horaria es GMT -6. Ahora son las 00:37.


Message Board Statistics

LinkBacks Enabled by vBSEO 3.1.0

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93