Foros del Web » Programando para Internet » PHP »

Error en filtro de busqueda

Estas en el tema de Error en filtro de busqueda en el foro de PHP en Foros del Web. Si tengo un formulario con campos de texto y selects, al enviar un formulario y lo proceso con lo siguiente: Código PHP: $strqry  =  "SELECT * FROM inventariosl where " ...
  #1 (permalink)  
Antiguo 06/03/2008, 08:03
(Desactivado)
 
Fecha de Ingreso: enero-2008
Ubicación: Mendoza
Mensajes: 458
Antigüedad: 16 años, 9 meses
Puntos: 2
Error en filtro de busqueda

Si tengo un formulario con campos de texto y selects, al enviar un formulario y lo proceso con lo siguiente:

Código PHP:
$strqry "SELECT * FROM inventariosl where "

if (
$dependencia !=="Seleccionar"){
$strqry.= "AND dependencia = '$dependencia'";}

if (
$nombre !==""){
$strqry.= "AND nombre = '$nombre'";}

if (
$ip !==""){
$strqry.= "AND ip  = '$ip '";}

if (
$inventariocpu !==""){
$strqry.= "AND inventariocpu = '$inventariocpu'";}

if (
$marcacpu !=="Seleccionar"){
$strqry.= "AND marcacpu = '$marcacpu'";}

if (
$modelocpu !=="Seleccionar"){
$strqry.= "AND modelocpu = '$modelocpu'";}

if (
$seriecpu !==""){
$strqry.= "AND seriecpu = '$seriecpu'";}

if (
$micro !=="Seleccionar"){
$strqry.= "AND micro = '$micro'";}

if (
$ram !=="Seleccionar"){
$strqry.= "AND ram = '$ram'";}

if (
$red !=="Seleccionar"){
$strqry.= "AND red = '$red'";}

if (
$sp !=="Seleccionar"){
$strqry.= "AND sp = '$sp'";}

if (
$servicepack !=="Seleccionar"){
$strqry.= "AND servicepack = '$servicepack'";}

if (
$marcamonitor !=="Seleccionar"){
$strqry.= "AND marcamonitor = '$marcamonitor'";}

if (
$modelomonitor !=="Seleccionar"){
$strqry.= "AND modelomonitor = '$modelomonitor'";}

if (
$inventariomonitor !==""){
$strqry.= "AND inventariomonitor = '$inventariomonitor'";}

if (
$seriemonitor !==""){
$strqry.= "AND seriemonitor = '$seriemonitor'";}

if (
$inventarioups !==""){
$strqry.= "AND inventarioups = '$inventarioups'";}

if (
$marcaups !=="Seleccionar"){ $strqry.= " AND marcaups = '$marcaups'";}

if (
$modeloups !=="Seleccionar"){ $strqry.= " AND modeloups = '$modeloups'";}

if (
$serieups !==""){ 
$strqry.= "AND serieups = '$serieups'";}

if (
$inventarioimp !==""){
$strqry.= "AND inventarioimp = '$inventarioimp'";}

if (
$marcaimp !=="Seleccionar"){$strqry.= "AND marcaimp = '$marcaimp'";}

if (
$modeloimp !=="Seleccionar"){ $strqry.= "AND modeloimp = '$modeloimp'";}

if (
$serieimp !==""){
$strqry.= "AND serieimp = '$serieimp'";}

if (
$ipimp !==""){
$strqry.= "AND ipimp = '$ipimp'";}

$sqry mysql_query($strqry,$link);
$result mysql_query($strqry,$link);
$numeroregistros=mysql_num_rows($result);
echo 
'<br /><font size=2 face=verdana color=000000>Cantidad de Registros Encontrados: <b>'.$numeroregistros.'</b></font>';

$found false;

while (
$row mysql_fetch_assoc($sqry)){ 
$found true;
echo 
"Aqui las respuestas";

Solo me funciona cuando selecciono la dependencia, pero si quiero buscar por solamente otro valor... me salta error siguiente:

Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in C:\servidor\web\sistemanetcom\sistema\inventario\c onsultar\proceso_datos.php on line 185

Cantidad de Registros Encontrados:
Warning: mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in C:\servidor\web\sistemanetcom\sistema\inventario\c onsultar\proceso_datos.php on line 190



POr ejemplo quiero buscar solamente los modelos 840C y si no coloco otra cosa me salta error.... ayuda plis
  #2 (permalink)  
Antiguo 06/03/2008, 08:14
Avatar de quinqui  
Fecha de Ingreso: agosto-2004
Ubicación: Chile!
Mensajes: 776
Antigüedad: 20 años, 3 meses
Puntos: 56
Re: Error en filtro de busqueda

Antes de enviar la consulta con mysql_query(), imprime en pantalla la consulta que has armado con todas esas condicionantes. A la rápida creo ver que las palabras están quedando pegadas.... (algo como "select * from tabla where condicion = 'hola'AND condicion2 = 'chau'").

Código PHP:
if ($ipimp !==""){
$strqry.= "AND ipimp = '$ipimp'";}

echo 
$strqry;

$sqry mysql_query($strqry,$link); 
__________________
pipus.... vieeeeeji plomius!!!
*quinqui site*
  #3 (permalink)  
Antiguo 14/03/2008, 04:21
 
Fecha de Ingreso: marzo-2008
Mensajes: 1
Antigüedad: 16 años, 8 meses
Puntos: 0
Re: Error en filtro de busqueda

Hola como esta todo? Me acabo de registrar pero creo que te puedo ayudar.
Fijate que cuando queres que concatene si algo es distinto de las values, te concatena el AND entonces la primera vez que concatena te queda

select * from <tabla> where AND dependencia = '$dependencia'";}

Tambien tenes que dejar espacios antes del AND quedando asi

$strqry.= " AND dependencia = '$dependencia'";

Saludos, espero que te haya ayudado.
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 21:30.