ホームページ >データベース >mysql チュートリアル >php+mysqlを使ってショッピングカート機能を実装する方法

php+mysqlを使ってショッピングカート機能を実装する方法

PHPz
PHPz転載
2023-05-27 15:43:261863ブラウズ

1. ショッピング カート機能の概要

ショッピング カートは、オンライン モールの核となる機能であり、ユーザーは購入する必要がある商品を追加できます。ショッピングカートに追加し、今後の注文の準備をします。注文と支払いをより適切に管理するために、ユーザーはショッピング カートで商品の数量を変更したり、商品を削除したりできます。

2. ショッピング カートを実装する基本手順

PHP と MySQL を使用してショッピング カート機能を実装する前に、まず基本的な手順を見てみましょう。ショッピング カートの実装:

  • データベース テーブルの作成: ショッピング カートの情報を保存するデータベース テーブルを作成する必要があります。

  • ショッピング カートに追加するコードを作成します。ユーザーがショッピング カートに商品を追加するとき、対応するデータをデータベースに追加する必要があります。

  • ショッピング カートを表示するコードを作成します。ユーザーがショッピング カートを表示するときは、関連するデータをデータベースから取得して表示する必要があります。

  • ショッピング カートを変更するコードを作成する: ユーザーがショッピング カート内のアイテムを変更または削除すると、データベース内の対応するデータを更新する必要があります。

#3. データベース テーブルの作成

まず、ショッピング カートの情報を保存するデータベース テーブルを作成する必要があります。次に例を示します。

CREATE TABLE `cart` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `product_name` varchar(255) NOT NULL,
  `product_price` decimal(10,2) NOT NULL,
  `product_quantity` int(11) NOT NULL,
  `user_id` int(11) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

このテーブルには、次の情報を保存します。

  • 製品名: product_name

  • #商品価格: product_price

  • 商品数量: product_quantity

  • ユーザー ID: user_id

4. ショッピング カートに追加するコードを作成します##ユーザーがショッピング カートに商品を追加するとき、対応するデータをデータベースに追加する必要があります。以下は、ショッピング カートに商品を追加するための基本的なコード例です。

<?php

$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

// 获取要添加到购物车的商品信息
$product_name = $_POST[&#39;product_name&#39;];
$product_price = $_POST[&#39;product_price&#39;];
$product_quantity = $_POST[&#39;product_quantity&#39;];
$user_id = $_POST[&#39;user_id&#39;];

// 将商品添加到购物车
$sql = "INSERT INTO cart (product_name, product_price, product_quantity, user_id) 
VALUES (&#39;$product_name&#39;, &#39;$product_price&#39;, &#39;$product_quantity&#39;, &#39;$user_id&#39;)";

if ($conn->query($sql) === TRUE) {
    echo "商品已成功添加到购物车。";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}

$conn->close();

?>

ここでは、mysqli を使用して MySQL データベースに接続し、データを追加する前にいくつかの基本的な接続チェックを実行していることに注意してください。

5. ショッピング カートを表示するコードを記述する

ユーザーがショッピング カートを表示するときは、関連するデータをデータベースから取得して表示する必要があります。ショッピング カート情報を表示する基本的なコード例を次に示します。

<?php

$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

// 获取购物车信息
$sql = "SELECT * FROM cart WHERE user_id = &#39;123&#39;"; // 请将user_id替换为当前登录用户的ID

$result = $conn->query($sql);

if ($result->num_rows > 0) {
    // 输出每一行数据
    while($row = $result->fetch_assoc()) {
        echo "商品名称:" . $row["product_name"]. ",价格:" . $row["product_price"]. ",数量:" . $row["product_quantity"]. "<br>";
    }
} else {
    echo "购物车为空。";
}

$conn->close();

?>

ここでは、結果セットに行が含まれているかどうかを確認し、while ループを使用してデータの各行を出力していることに注意してください。

6. ショッピング カートを変更するコードを作成します

ユーザーがショッピング カート内のアイテムを変更または削除した場合、対応するデータベース データを更新する必要があります。ショッピング カートの内容を変更する基本的なコード例を次に示します:

<?php

$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";

// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

// 获取要修改的商品信息
$product_name = $_POST[&#39;product_name&#39;];
$product_price = $_POST[&#39;product_price&#39;];
$product_quantity = $_POST[&#39;product_quantity&#39;];
$user_id = $_POST[&#39;user_id&#39;];

// 更新购物车中商品信息
$sql = "UPDATE cart SET product_price = &#39;$product_price&#39;, product_quantity = &#39;$product_quantity&#39; WHERE user_id = &#39;$user_id&#39; AND product_name = &#39;$product_name&#39;";

if ($conn->query($sql) === TRUE) {
    echo "购物车信息已成功更新。";
} else {
    echo "Error: " . $sql . "<br>" . $conn->error;
}

$conn->close();

?>

以上がphp+mysqlを使ってショッピングカート機能を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。