Foros del Web » Programando para Internet » PHP »

Problemas al mostrar resultados

Estas en el tema de Problemas al mostrar resultados en el foro de PHP en Foros del Web. Hola amigos, hace poco añadi a mi home un top de los ultimos 10 mensajes del foro con php. Ahora quiero usar el mismo codigo ...
  #1 (permalink)  
Antiguo 18/08/2008, 21:32
Avatar de eminem24  
Fecha de Ingreso: julio-2008
Mensajes: 68
Antigüedad: 15 años, 9 meses
Puntos: 0
Problemas al mostrar resultados

Hola amigos, hace poco añadi a mi home un top de los ultimos 10 mensajes del foro con php. Ahora quiero usar el mismo codigo para mostrar los ultimos 10 articulos de otra sección pero no lo consigo.

Este es el codigo que utilizo:

Código PHP:
<?php
// Edita lo que viene a continuación. Cambia solo lo que hay entre comillas "":

$directorio "/articulos"//Carpeta donde esta situada la sección articulos.
$mostrar "10"//Número de mensajes a mostrar.
$caracteres "50"//Caracteres que se mostrarán de cada línea.

$dbhost 'mysql.miweb.com';  //nombre de host
$dbname 'miweb_articulos';  //nombre de la base de datos
$dbuser 'admin';  //usuario de la base de datos
$dbpasswd 'password';  //contraseña ...
$table_prefix 'news_';  // prefijo de la tabla

$conexion mysql_connect($dbhost,$dbuser,$dbpasswd);
mysql_select_db($dbname,$conexion);
$consulta "select * from ".$table_prefix."posts order by post_time desc";
$resultado mysql_query($consulta);
$i 1;
    echo 
"<table width=100% bgcolor=#FFFFFF><tr><td colspan=2></td></tr>";
while (
$rows mysql_fetch_array($resultado)) {
if (
$i <= $mostrar) {
$consulta1 "select * from ".$table_prefix."forums where articles_id='$rows[articles_id]'";
$resultado1 mysql_query($consulta1);
$datosf mysql_fetch_array($resultado1);
$consulta2 "select * from ".$table_prefix."users where categories_id='$rows[categories_id]'";
$resultado2 mysql_query($consulta2);
$datosu mysql_fetch_array($resultado2);
if (
strlen($datost[articles]) > $caracteres) {
$datost[articles] = substr($datost[articles],0,48)."...";  // el 49 es el límite de carácteres que muestra antes de los puntos
}

   echo 
"<tr><td><font size=0><a href=\"$directorio/index.php?id=$rows[articles_id]\" class=\"enlaces-dos\">$datost[articles]</a></font><font face=verdana color=#888888 size=0>en <i>$datosf[categories]</i></font></td></tr>";
$i++;
}
}
echo 
"<tr><td colspan=2 id=subnav name=subnav><a href=$directorio/index.php><font size=0><br></font></a></td></tr></table>";
mysql_free_result($resultado);
mysql_close($conexion);
?>
Ya le he añadido los datos de la otra base de datos, aunque seguro que en algo me he equivocado. Este es el error que me sale:

Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in /mnt/local/home/miweb/miweb.com/ultimos-articulos.php on line 20

Warning: mysql_free_result(): supplied argument is not a valid MySQL result resource in /mnt/local/home/miweb/miweb.com/ultimos-articulos.php on line 37


Este error me aparece en la home, donde tengo un include a ultimos-articulos.php ,que es donde está el primer código.

Espero que alguien me pueda ayudar, podeis decirme otro codigo para utilizar si quereis. Saludos a todos y gracias anticipadas.
  #2 (permalink)  
Antiguo 19/08/2008, 01:29
Colaborador
 
Fecha de Ingreso: marzo-2008
Ubicación: Cáceres
Mensajes: 3.735
Antigüedad: 16 años
Puntos: 300
Respuesta: Problemas al mostrar resultados

En MySQL se limita el número de filas recogidas con LIMIT. La consulta debería ser:
select campo1, campo2 from news_posts order by post_time desc LIMIT 10
Evita el uso del asterisco y pon tras select los campos que vayas a usar...
Por tanto, el if se hace innecesario. Este es un foro de base de datos y no debemos poner variables, por lo que aquí no puedo decirte nada al respecto de la sintaxis PHP que estás utilizando. Lanza esa consulta MYSQL directamente en consola o con PHPMyAdmin. Si el resultado es el esperado, yo te recomendaría que hicieras las otras dos consultas directamente sin hacerlo desde PHP. Imagino que en la tabla news_posts hay unos campos llamados articles_id y categories_id, y supongo que serán numéricos. Si es así y en las tablas news_forums y news_users aparecen los articles_id y categories_id encontrados en las primeras consultas (hazlo directamente en la consola o desde PHPMyAdmin), los problemas te vendrán de la sintaxis PHP. He observado algunos errores del PHP (datos numéricos con comillas simples, ausencia de comillas simples), pero, como te he dicho, este no es el foro adecuado. Si en consola o con PHPMyAdmin te funciona bien la consulta, es el momento de pedir ayuda en el foro PHP.
  #3 (permalink)  
Antiguo 19/08/2008, 06:01
Avatar de eminem24  
Fecha de Ingreso: julio-2008
Mensajes: 68
Antigüedad: 15 años, 9 meses
Puntos: 0
Respuesta: Problemas al mostrar resultados

Gracias Jurena, repasaré lo que me dices y moveré este tema a la seccion de php. Saludos! Por cierto, como muevo el tema para no crear otro?
  #4 (permalink)  
Antiguo 19/08/2008, 08:26
Avatar de BrujoNic
Super Moderador
 
Fecha de Ingreso: noviembre-2001
Ubicación: Costa Rica/Nicaragua
Mensajes: 16.935
Antigüedad: 22 años, 5 meses
Puntos: 655
Respuesta: Problemas al mostrar resultados

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
__________________
La tecnología está para ayudarnos. No comprendo el porqué con esa ayuda, la gente escribe TAN MAL.
NO PERDAMOS NUESTRO LINDO IDIOMA ESPAÑOL
  #5 (permalink)  
Antiguo 19/08/2008, 09:30
Avatar de Carlojas  
Fecha de Ingreso: junio-2007
Ubicación: Shikasta
Mensajes: 1.272
Antigüedad: 16 años, 10 meses
Puntos: 49
Respuesta: Problemas al mostrar resultados

Que tal eminem24, verifica que no tengas errores en las consultas que intentas ejecutar prueba así tu código:

Código PHP:
$conexion mysql_connect($dbhost,$dbuser,$dbpasswd);
mysql_select_db($dbname,$conexion);
$consulta "select * from ".$table_prefix."posts order by post_time desc";
$resultado mysql_query($consulta$conexion) or die("Error en consulta $consulta:".mysql_error() );
$i 1;
echo 
"<table width=100% bgcolor=#FFFFFF><tr><td colspan=2></td></tr>";
while (
$rows mysql_fetch_array($resultado)) {
if (
$i <= $mostrar) {
$consulta1 "select * from ".$table_prefix."forums where articles_id='$rows[articles_id]'";
$resultado1 mysql_query($consulta1$conexion) or die("Error en consulta1 $consulta1:".mysql_error() );
$datosf mysql_fetch_array($resultado1);
$consulta2 "select * from ".$table_prefix."users where categories_id='$rows[categories_id]'";
$resultado2 mysql_query($consulta2$conexion) or die("Error en consulta2 $consulta2:".mysql_error() );
$datosu mysql_fetch_array($resultado2); 
Saludos.

Última edición por Carlojas; 20/08/2008 a las 08:23
  #6 (permalink)  
Antiguo 20/08/2008, 22:19
Avatar de eminem24  
Fecha de Ingreso: julio-2008
Mensajes: 68
Antigüedad: 15 años, 9 meses
Puntos: 0
Respuesta: Problemas al mostrar resultados

Muchas gracias Carlojas, lo probare haber que tal y te cuento. 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 05:30.