PHP を使用した簡単なオンライン オークション システムの実装方法
今日のデジタル時代において、オンライン オークション システムはますます人気が高まっています。このシステムにより、インターネット上で商品オークションを実施することができ、より幅広い参加とより高い利益を得ることができます。この記事では、PHP を使用して簡単なオンライン オークション システムを作成する方法と具体的なコード例を紹介します。
まず、オークション関連の情報を保存するデータベースを作成する必要があります。 MySQL では、次の SQL ステートメントを使用して、auction という名前のデータベースを作成できます:
CREATE DATABASE Auction;
次に、オークションのアイテム情報を保存するための items という名前のテーブルを作成する必要があります。テーブルには、id (オークション アイテム ID)、name (オークション アイテム名)、description (オークション アイテムの説明)、start_price (開始価格)、current_price (現在の価格)、end_time (終了時間) などのフィールドが含まれています。次の SQL ステートメントを使用してテーブルを作成できます。
CREATE TABLE items (
id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255) NOT NULL, description TEXT, start_price INT NOT NULL, current_price INT NOT NULL, end_time DATETIME NOT NULL
);
次に、PHP コードを記述して、オークションシステム。まず、データベースに接続する必要があります。次のコードを使用してデータベースに接続できます:
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "オークション";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
?>
次に、オークション商品リストとオークション情報を表示するための、index.php という名前のファイルを作成します。このファイルでは、データベースにクエリを実行してすべてのオークション商品情報を取得し、それをページに表示する必要があります。これは、次のコードを使用して実現できます:
$sql = "SELECT * FROM items";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) { echo "拍卖品ID: " . $row["id"]. " - 拍卖品名称: " . $row["name"]. " - 当前价: " . $row["current_price"]. "<br>"; }
} else {
echo "暂无拍卖品";
}
?>
次に、オークション アイテムに対するユーザーの入札操作を実装するために、auction.php という名前のファイルを作成できます。このファイルでは、ユーザーが入力した入札価格を取得し、データベース内の現在の価格を更新する必要があります。これは、次のコードを使用して実現できます:
if ($_SERVER["REQUEST_METHOD"] == "POST") { // リクエスト メソッドが POST
であるかどうかを確認します。$item_id = $_POST["item_id"]; $bid_price = $_POST["bid_price"]; $sql = "SELECT * FROM items WHERE id = {$item_id}"; $result = $conn->query($sql); if ($result->num_rows > 0) { $row = $result->fetch_assoc(); if ($bid_price > $row["current_price"]) { $sql = "UPDATE items SET current_price = {$bid_price} WHERE id = {$item_id}"; if ($conn->query($sql) === TRUE) { echo "竞拍成功"; } else { echo "竞拍失败: " . $conn->error; } } else { echo "出价过低"; } } else { echo "拍卖品不存在"; }
}
?>
最後に、特定のオークション アイテムに対するユーザーの入札インターフェイスを実装するために、bid.php という名前のファイルを作成する必要があります。このファイルでは、フォームを使用してユーザーの入札を受け取り、それを処理のために Auction.php に送信する必要があります。これは、次のコードを使用して実現できます: