Foros del Web » Programando para Internet » PHP »

query con dos where

Estas en el tema de query con dos where en el foro de PHP en Foros del Web. Veréis, tengo el siguiente código Código PHP: $colname_relatedpages  =  "-1" ; if (isset( $_GET [ 'pagecategory' ])) {    $colname_relatedpages  =  $_GET [ 'pagecategory' ]; } mysql_select_db ...
  #1 (permalink)  
Antiguo 05/09/2007, 14:59
Avatar de sumolari  
Fecha de Ingreso: mayo-2006
Ubicación: localhost
Mensajes: 1.367
Antigüedad: 18 años, 6 meses
Puntos: 18
query con dos where

Veréis, tengo el siguiente código
Código PHP:
$colname_relatedpages "-1";
if (isset(
$_GET['pagecategory'])) {
  
$colname_relatedpages $_GET['pagecategory'];
}
mysql_select_db($database_database$database);
$query_relatedpages sprintf("SELECT * FROM pages WHERE pagecategory = %s"GetSQLValueString($colname_relatedpages"text"));
$relatedpages mysql_query($query_relatedpages$database) or die(mysql_error());
$row_relatedpages mysql_fetch_assoc($relatedpages);
$totalRows_relatedpages mysql_num_rows($relatedpages); 
El código carga de la base de datos las filas que contengan en la columna "pagecategory" el contenido de una variable de URL llamada "pagecategory".

Ahora me gustaría hacer que además de filtrar por "pagecategory" también me filtrase la columna "published", mostrando sólo las filas que tengan el valor "true".

Vamos, que "debería" quedar así
Código PHP:
if (isset($_GET['pagecategory'])) {
  
$colname_relatedpages $_GET['pagecategory'];
}
mysql_select_db($database_database$database);
$query_relatedpages "SELECT * FROM pages WHERE published = 'true'";
$relatedpages mysql_query($query_relatedpages$database) or die(mysql_error());
$row_relatedpages mysql_fetch_assoc($relatedpages);
$totalRows_relatedpages mysql_num_rows($relatedpages); 
Pero no funciona, sólo "hace caso" del primer where, en este caso el de published = true.

¿Cómo debo hacer para que funcionen los dos where?

P.D.: Código generado por Dreamweaver (el segundo por Copiar-Pegar).

Gracias por la ayuda
  #2 (permalink)  
Antiguo 05/09/2007, 15:08
Avatar de Mignola  
Fecha de Ingreso: noviembre-2002
Ubicación: Templo Shaolin
Mensajes: 167
Antigüedad: 22 años
Puntos: 1
Re: query con dos where

Hola,

"SELECT * FROM pages WHERE pagecategory = %s AND published = 'true'"?
  #3 (permalink)  
Antiguo 05/09/2007, 15:10
Avatar de ginitofl  
Fecha de Ingreso: diciembre-2006
Ubicación: Lima Perú
Mensajes: 349
Antigüedad: 17 años, 11 meses
Puntos: 22
Re: query con dos where

Hola solo tendrias que hacer una consulta, no es necesario los dos, lo tienes que hacer de esta manera:


Código PHP:
if (isset($_GET['pagecategory'])) {
  
$colname_relatedpages $_GET['pagecategory'];
}
mysql_select_db($database_database$database);
$query_relatedpages "SELECT * FROM pages WHERE pagecategory ='$colname_relatedpages' and published = 'true'";
$relatedpages mysql_query($query_relatedpages$database) or die(mysql_error());
$row_relatedpages mysql_fetch_assoc($relatedpages);
$totalRows_relatedpages mysql_num_rows($relatedpages); 
  #4 (permalink)  
Antiguo 05/09/2007, 23:46
Avatar de sumolari  
Fecha de Ingreso: mayo-2006
Ubicación: localhost
Mensajes: 1.367
Antigüedad: 18 años, 6 meses
Puntos: 18
Re: query con dos where

OK, mochas gracias por vuestra ayuda
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:51.