|
Smarty
WARNING: All discussion is moving to https://reddit.com/r/smarty, please go there! This forum will be closing soon. |
|
View previous topic :: View next topic |
Author |
Message |
Las Smarty n00b
Joined: 05 Oct 2008 Posts: 2
|
Posted: Sun Oct 05, 2008 1:55 pm Post subject: Requete mysql ne s'execute pas |
|
|
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 |
|
lequebecois Smarty n00b
Joined: 10 Oct 2008 Posts: 1
|
Posted: Fri Oct 10, 2008 8:10 pm Post subject: Erreur dans ton assign |
|
|
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 |
|
Las Smarty n00b
Joined: 05 Oct 2008 Posts: 2
|
Posted: Mon Oct 20, 2008 5:42 pm Post subject: |
|
|
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 |
|
|
|
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
|