私は、ウェブサイトにPHPを使用して簡単なeコマースエンジンを構築するための小さな大学の課題に取り組んでいます。
現在、カテゴリ内の製品を表示するために次のスクリプトを設定しています。これらはすべてMySQLデータベースから取得されます。
http://example.com/category.php?id=2
私が現在抱えている問題は、表示されている各製品について、スクリプトがそれぞれを並べて新しいテーブルエントリにエコーしているだけであるということです。これにより、垂直方向ではなくページを横切って移動します。
このコードを変更して、たとえば行ごとに最大3つの製品を含めるための最良の方法は何でしょうか。それらの線に沿ったIfループまたは何か?サポートをいただければ幸いです!
<?php
//Create Session
session_start();
//Connect to database
include "conn.php";
//Retrieve Header
include "header.php";
//Get Category ID
if (isset($_GET['id'])){
$CategoryID = $_GET['id'];
//QUERY collects product name, and product ID.
$q="SELECT ProductID, ProductName, Price,img FROM Products WHERE CategoryID=$CategoryID";
//QUERY collects Product Category descriptions
$d="SELECT `Desc` FROM ProductCategories WHERE CategoryID=$CategoryID";
//retrive and execute SQL query results and save into a variable
$result = mysqli_query($_SESSION['conn'],$q);
$result2 = mysqli_query($_SESSION['conn'],$d) or die(mysql_error());
//Retrieve Product Category Description
echo "<div>";
while ($myResult = mysqli_fetch_row($result2)){ //Create an array
echo "<p>".$myResult[0]."</p>";
}
echo "</div>";
//Retrieve Products in category
echo "<div align='center'><table border='1px' bordercolor='#000000' width='200px'><tr>"; //Define table, row and div containing each product
while ($row = mysqli_fetch_row($result)){ //Create an array
echo "<td>"; //Create table cell
echo "<p><img src=".$row[3]."></p>"; //product image small (250x250 Pixels)
echo "<p align='center'><a href='product.php?id=".$row[0]."'>".$row[1]." </a></p>"; //Product ID Link and Name
echo "<p align='center'>£ ".$row[2]."</p>";
echo "</td>"; //Close table cell
}
echo "</tr></table></div>";//Close table, div and row
mysqli_free_result($result);
}
// Retireve Footer
include "footer.php";
?>
私はどんな種類のプログラミングに関しても新しいので、あなたが私に与えることができる忍耐/どんなサポートにも感謝します。また、SQLインジェクションの問題を認識しており、後日修正する予定です。