私の「人気のあるタグ」ページでは、この PHP と SQL を使用してデータベースからすべてのタグを、最も人気のあるものから最も人気のないものの順にフェッチしています。
$sql = "SELECT t.tagid, t.name, t.desc, COUNT(qt.id) AS total
FROM tags t
LEFT JOIN question_tags qt ON t.tagid=qt.tag_id
GROUP BY t.tagid, t.name
ORDER BY total DESC";
$result = mysql_query($sql) or die(mysql_error());
while($row=mysql_fetch_assoc($result)) {
echo '<div class="tag-list-box" id="tag-'.$row['tagid'].'">
<a href="/tags/'.strtolower($row['name']).'" class="tag">
<span class="label label-inverse label-tag">'.strtolower($row['name']).'</span>
</a> <strong>× '.$row['total'].'</strong><br />
<p>'.($row['desc']!==null ? $row['desc'] : '<em>This tag has no description.</em>').'</p>
</div>';
}
div と CSS を使用してより「現代的な方法」で実行できると思ったので、現在 HTML テーブルにはありませんが、下のスクリーンショットでわかるように、タグにボックスの高さが他よりも大きいため、説明:
ボックスの私の CSS は次のとおりです。
.tag-list-box {
width: 20%;
padding: 5px;
background-color: #f0f0f0;
border: 1px solid #ccc;
float: left;
margin-right: 2%;
margin-bottom: 10px;
}
問題を解決する必要があるテーブルに配置する必要があると考えていますが、クエリの4行ごとに独自のものを作成して<tr>
、各テーブル行に4つ存在できるようにするにはどうすればよいですか?
私はそれを理解することができません - 私はループでカウントしてインクリメントしようとしましたwhile
が、そこからどこに行くべきかわかりません.