Foros del Web » Programando para Internet » PHP »

Error al mostrar resultados busqueda

Estas en el tema de Error al mostrar resultados busqueda en el foro de PHP en Foros del Web. Buenas, tengo una base de datos de una biblioteca programada en php que, seleccionando el autor, la editorial y el idioma, me manda a una ...
  #1 (permalink)  
Antiguo 02/10/2007, 16:57
 
Fecha de Ingreso: enero-2005
Mensajes: 46
Antigüedad: 19 años, 2 meses
Puntos: 0
Error al mostrar resultados busqueda

Buenas,

tengo una base de datos de una biblioteca programada en php que, seleccionando el autor, la editorial y el idioma, me manda a una pag. en la que debería mostrarme todos los resultados que coincidan con esa pag., pero me da error.

Este es el código:

Código PHP:
<html>
<head><title>Lista de libros</title></head>
<body>
    <h1>Listado de libros</h1>
    <p><a href="libros.php">Nueva búsqueda</a></p>
    <?php
    $bd
=mysql_connect('localhost''usuario''contraseña');
    
mysql_select_db("biblioteca");
    
$select="SELECT DISTINCT libros.ID, libros.TID, libros.LID, libros.EID, titulo, autores.ID, autor,
    editorial.EID, nombre, idioma.LID, idioma"
;
    
$from="WHERE libros, autores, editorial, idioma";
    
$where="WHERE libros.TID > 0 AND autores.ID=libros.ID AND editorial.EID=libros.EID AND
    idioma.LID=libros.LID"
;
    if (
$aid != "") {
        
$where .= " AND libros.ID=$aid";
    }
    if (
$eid != "") {
        
$where .= " AND EID=$eid";
    }
    if (
$lid != "") {
        
$where .= " AND idioma.LID=$lid";
    }
    if (
$searchtext != "") {
        
$where .= " AND titulo LIKE '%$searchtext%'";
    }
    
?>
    <table border="1">
    <tr>
    <th>Título</th><th>Autor</th><th>Idioma</th><th>Editorial</th>
    </tr>
    <?php
    $bus
=mysql_query($select $from $where);
    if (!
$bus) {
    echo(
"</table>");
    echo(
"<p>Error!<br>""Error: " mysql_error() . "</p>");
    exit();
    }
    while (
$bu=mysql_fetch_array($bus)) {
    echo(
"<tr valign='top'>\n");
    
$id=$bu["id"];
    
$tit=htmlspecialchars($bu["titulo"]);
    
$nombre=htmlspecialchars($bu["nombre"]);
    
$idio=htmlspecialchars($bu["idioma"]);
    
$edi=htmlspecialchars($bu["editorial"]);
        echo(
"<td>$tit</td>\n");
        echo(
"<td>$nombre</td>\n");
        echo(
"<td>$idio</td>\n");
        echo(
"<td>$edi</td>\n");
        echo(
"</tr>\n");
    }
    
?>
    </table>
</body>
</html>
No soy capaz de encontrarle el error por ninguna parte.

Gracias y saludos.
  #2 (permalink)  
Antiguo 02/10/2007, 19:04
 
Fecha de Ingreso: septiembre-2007
Ubicación: Argentina
Mensajes: 29
Antigüedad: 16 años, 7 meses
Puntos: 0
Re: Error al mostrar resultados busqueda

Código PHP:
$from="FROM libros, autores, editorial, idioma"
  #3 (permalink)  
Antiguo 03/10/2007, 03:10
 
Fecha de Ingreso: enero-2005
Mensajes: 46
Antigüedad: 19 años, 2 meses
Puntos: 0
Re: Error al mostrar resultados busqueda

Buenas,

gracias por la respuesta. Tuve un pequeño fallo sintáctico La lástima es que el fallo no es ese. Me sigue dando el mismo error. Mira, os copio el error a ver si veis algo, porque yo en la línea que me dice lo veo todo bien.

Error!
Error: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '.TID > 0 AND autores.ID=libros.ID AND editorial.EID=libros.EID AND idioma.LID=' at line 2

Gracias y saludos.
  #4 (permalink)  
Antiguo 03/10/2007, 09:34
Avatar de Seppo  
Fecha de Ingreso: marzo-2005
Ubicación: Buenos Aires, Argentina
Mensajes: 1.284
Antigüedad: 19 años, 1 mes
Puntos: 17
Re: Error al mostrar resultados busqueda

Código PHP:
$from="FROM libros, autores, editorial, idioma "
Agregale un espacio al final... si sigue sin andar, en vez de
Código PHP:
    $bus=mysql_query($select $from $where); 
Poné
Código PHP:
die($select $from $where); 
Y fijate la consulta entera y copiala para verlo más fácil
  #5 (permalink)  
Antiguo 03/10/2007, 16:05
 
Fecha de Ingreso: enero-2005
Mensajes: 46
Antigüedad: 19 años, 2 meses
Puntos: 0
Re: Error al mostrar resultados busqueda

Buenas,

nada, con ninguna de las dos soluciones se ha arreglado el fallo. Os pongo el código de la pag. que manda la consulta, a ver si así veis algo:

Código PHP:
<html>
<head><title>Gestión de libros</title></head>
<body>
    <h1>Gestión de libros</h1>
    <p><a href="nuevolibro.php">Añadir un nuevo libro</a></p>
    <?php
    $bd
=@mysql_connect('localhost''usuario''contraseña');
    
mysql_select_db("biblioteca");
    
$authors=mysql_query("SELECT ID, autor FROM autores");
    
$cats=mysql_query("SELECT EID, nombre FROM editorial");
    
$idioms=mysql_query("SELECT LID, idioma FROM idioma");
    
?>
    <form action="listalibros.php" method="post">
    <p>Ordenar los libros según el siguiente criterio:<br>
    Por autor:
    <select name="tid" size="1">
    <option selected value="">Todos los autores</option>
    <?php
    
while ($author=mysql_fetch_array($authors)) {
    
$tid=$author["ID"];
    
$aname=htmlspecialchars($author["autor"]);
    echo(
"<option value='$tid'>$aname</option>\n");
    }
    
?>
    </select><br>
    Por editorial:
    <select name="eid" size="1">
    <option selected value="">Todas las editoriales</option>
    <?php
    
while ($cat=mysql_fetch_array($cats)) {
    
$eid=$cat["EID"];
    
$cname=htmlspecialchars($cat["nombre"]);
    echo(
"<option value='$eid'>$cname</option>\n");
    }
    
?>
    </select><br>
    Por idioma:
    <select name="lid" size="1">
    <option selected value="">Todos los idiomas</option>
    <?php
    
while ($idiom=mysql_fetch_array($idioms)) {
    
$lid=$idiom["LID"];
    
$lname=htmlspecialchars($idiom["idioma"]);
    echo(
"<option value='$lid'>$lname</option>\n");
    }
    
?>
    </select><br>
    Que incluya el texto: <input type="text" name="searchtext">
    <br>
    <input type="submit" name="submit" value="BUSCAR">
    </form>
    <p align="center"><a href="index.html">Volver a la página principal</a></p>
</body>
</html>
Gracias por las molestias.
Saludos-
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:19.