Smarty Forum Index Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon.

Requete mysql ne s'execute pas

 
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: French
View previous topic :: View next topic  
Author Message
Las
Smarty n00b


Joined: 05 Oct 2008
Posts: 2

PostPosted: Sun Oct 05, 2008 1:55 pm    Post subject: Requete mysql ne s'execute pas Reply with quote

Bonjour,
j'ai une base de donnée plein de news, et j'aimerai bien afficher dans une sidebar le top10 des articles les plus affichés.

voici mon code dans sidebar.php
Code:
<?php

require '../libs/Smarty.class.php';

$smarty = new Smarty;

$connexion = mysql_connect("localhost", "root", "");

mysql_select_db("mabase", $connexion);

$top10 = mysql_query("SELECT id, titles FROM news ORDER BY affichages LIMIT 10");

while(mysql_num_rows($top10)){

$smarty->assign('results', mysql_fetch_array($top10));

}

$smarty->display('../templates/sidebar.tpl');

?>


et dans ma sidebar.tpl :
Code:
{foreach key=id item=con from=$results}

<a href="article.php?id={$id}">{$con.title}</a><br />

{foreachelse}

Pas de contenu à afficher.

{/foreach}



dans le top 10 s'affiche "Pas de contenu à afficher" comme si smarty ne voyait pas les enregistrements dans ma base.

une idée svp ??
Back to top
View user's profile Send private message
lequebecois
Smarty n00b


Joined: 10 Oct 2008
Posts: 1

PostPosted: Fri Oct 10, 2008 8:10 pm    Post subject: Erreur dans ton assign Reply with quote

Salut,
Je ne pense pas que tu puisses utiliser assign comme ça. Tu dois mettre tes donnés dans un array, et puis faire le assign. Comme ceci:

while(mysql_num_rows($top10)){
arrMonInfo[] = mysql_fetch_array($top10)

}
$smarty->assign('results', arrMonInfo);

Si je comprend bien smarty (chose qui n'est vraiment pas certaine) le assign ne fait que donner un nouveau nom à la variable. En fait, à ce que je sache, c'est une référence en mémoire, et donc, les donnés ne sont même pas déplacé. Ce qui m'a aidé à comprendre ceci est le fait que la fonction assign_by_ref() ne sert plus vraiment à grand chose depuis les nouvelles version de PHP dans lesquelles toutes les variables sont en fait des références jusqu'à ce que les donnés changent. Vu que l'on modifie rarement les donnée dans les fichiers .tpl, les données ne sont, à ma connaissance, jamais même copiés.

Dans ton implementation, tu prenais pour acquis que smarty "fait quelque chose" avec tes donnes, comme si tu pensais qu'en faisant un assign sur le même nom, que smarty créerait un array avec tes donnés.

En fait, en étudiant ton exemple, j'aurais cru que tu aurais vu la dernière value tirée de la DB. Mais ... voilà.
Back to top
View user's profile Send private message
Las
Smarty n00b


Joined: 05 Oct 2008
Posts: 2

PostPosted: Mon Oct 20, 2008 5:42 pm    Post subject: Reply with quote

la requete s'execute normalement, et j'ai suivi un exemple dans un tuto trouvé sur internet mettant les resultats dans un array mais, rien ne s'affiche!!!
Back to top
View user's profile Send private message
Display posts from previous:   
This forum is locked: you cannot post, reply to, or edit topics.   This topic is locked: you cannot edit posts or make replies.    Smarty Forum Index -> Language: French All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group
Protected by Anti-Spam ACP