>백엔드 개발 >PHP 튜토리얼 >PHP를 사용하여 제품 다중 사양 SKU 기능을 구현하는 방법

PHP를 사용하여 제품 다중 사양 SKU 기능을 구현하는 방법

WBOY
WBOY원래의
2023-09-05 08:25:581646검색

PHP를 사용하여 제품 다중 사양 SKU 기능을 구현하는 방법

PHP를 사용하여 제품에 대한 다중 사양 SKU 기능을 구현하는 방법

제품에 대한 다중 사양 SKU는 전자상거래 플랫폼에서 공통된 제품 속성 설정으로 판매자가 동일한 제품에 대해 서로 다른 사양과 가격을 설정할 수 있습니다. 소비자의 다양한 요구를 충족시키기 위해 필요와 선호도에 따라 선택합니다. 이 기사에서는 PHP를 사용하여 제품의 다중 사양 SKU 기능을 구현하는 방법을 소개하고 해당 코드 예제를 제공합니다. 도움이 필요한 독자들에게 도움이 되기를 바랍니다.

1. 데이터 구조 설계

제품의 다중 사양 SKU 기능을 구현하기 전에 먼저 데이터베이스의 데이터 구조를 설계해야 합니다. 제품에 색상, 크기, 가격이라는 세 가지 사양이 있다고 가정합니다. 먼저 두 개의 데이터베이스 테이블을 생성해야 합니다. 하나는 사양 속성 정보를 저장하고 다른 하나는 SKU 정보를 저장합니다.

  1. 사양 속성 테이블(attributes)

CREATE TABLE attributes (attributes (
id int(11) NOT NULL AUTO_INCREMENT,
name varchar(255) NOT NULL,
PRIMARY KEY (id)
);

  1. SKU信息表(skus)

CREATE TABLE skus (
id int(11) NOT NULL AUTO_INCREMENT,
attribute_id int(11) NOT NULL,
value varchar(255) NOT NULL,
price decimal(10,2) NOT NULL,
PRIMARY KEY (id),
FOREIGN KEY (attribute_id)
REFERENCES attributes (id id int(11) NOT NULL AUTO_INCREMENT,

varchar(255) NOT NULL,

PRIMARY KEY (id)

);

  1. SKU 정보 테이블(skus)

CREATE TABLE skus (

id int(11 ) NOT NULL AUTO_INCREMENT,

attribute_id int(11) NOT NULL,
varchar(255) NOT NULL,
가격 십진수(10, 2) NOT NULL,

PRIMARY KEY(id),

FOREIGN KEY(attribute_id)
REFERENCES 속성(id) > >)
ON DELETE CASCADE
);

2. 백엔드 관리 페이지

사양 속성 목록 표시먼저 판매자가 추가 및 편집할 수 있도록 백엔드 관리 페이지에 사양 속성 목록을 표시해야 합니다. 사양 속성. //데이터베이스에 연결$conn = new mysqli("localhost", "username", "password", "database");// 사양 속성 목록 쿼리$query = "SELECT * FROM 속성";$result = $conn->query($query);
?>

사양 속성 이름


fetch_assoc()): ?>


name


사양 속성 추가 및 편집


판매자가 사양 속성을 추가하거나 편집해야 하는 경우 판매자가 작성하고 데이터베이스에 저장할 수 있는 해당 양식을 제공합니다.

if ($_SERVER['REQUEST_METHOD'] === 'POST') {

    // 양식 제출 처리
  1. $name = $_POST['name'];
// 사양 속성 저장 Database

$query = "속성 삽입(

) VALUES('{$name}')";

$conn->query($query);
}
?>

SKU 정보 표시//SKU 정보 목록 쿼리$query = "SELECT skus.*, attribute.name as 속성 FROM skus JOIN 속성 ON skus.attribute_id = attribute.id";$result = $conn-> ;query($query);사양 속성
백그라운드 관리 페이지에서 SKU 정보 목록을 표시해야 합니다. , 판매자가 SKU 정보를 추가하고 편집할 수 있습니다.
?>
🎜사양값🎜 🎜가격🎜 🎜 🎜 🎜 fetch_assoc()): ?> 🎜 🎜🎜 🎜🎜 🎜🎜 🎜 🎜 🎜
  1. SKU 정보 추가 및 편집

판매자가 SKU 정보를 추가하거나 편집해야 하는 경우 판매자가 작성하고 데이터베이스에 저장할 수 있는 해당 양식을 제공합니다.

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
// 양식 제출 처리
$attributeId = $_POST['attribute_id'];
$value = $_POST[' value'];
$price = $_POST['price'];

// SKU 정보를 데이터베이스에 저장
$query = "INSERT INTO skus (attribute_id, value, price) VALUES ('{$attributeId}', '{$value } ', '{$price}')";
$conn->query($query);
}
?>




<option value="" disabled selected>请选择规格属性</option>
<?php
// 查询规格属性列表
$query = "SELECT * FROM attributes";
$result = $conn->query($query);

while ($row = $result->fetch_assoc()):
?>
<option value="<?php echo $row['id']; ?>"><?php echo $row['name']; ?></option>
<?php endwhile; ?>







3. 프런트 데스크의 상품 상세 페이지

상품 상세 정보는 프런트 데스크에서 확인하세요. 프론트 데스크 페이지에는 제품의 사양 속성과 SKU 정보를 표시하고 사양 속성과 해당 SKU 정보를 선택하는 기능을 제공해야 합니다.

  1. 사양 속성 및 SKU 정보 표시

// 사양 속성 목록 쿼리
$query = "SELECT * FROM 속성";
$result = $conn->query($query);
?>






<script><br>$(document).ready(function() {<br> // 사양 속성 선택 청취 이벤트<br> $ ('#attribute').change(function() {</script>

var attributeId = $(this).val();

$.ajax({
  url: 'get_sku_info.php',
  method: 'POST',
  dataType: 'json',
  data: {attributeId: attributeId},
  success: function(data) {
    // 清空SKU信息显示区域
    $('#sku-info').empty();
    
    // 根据返回的SKU信息动态添加到显示区域
    $.each(data, function(index, item) {
      var skuHtml = '<div>';
      skuHtml += '<span>' + item.attribute + ': ' + item.value + '</span>';
      skuHtml += '<span>价格: ' + item.price + '</span>';
      skuHtml += '</div>';
      
      $('#sku-info').append(skuHtml);
    });
  }
});

});
});

  1. SKU 정보 가져오기

첫 페이지에서는 Ajax를 사용하여 요청해야 합니다. 해당 사양 속성에서 SKU 정보를 얻기 위한 백그라운드 인터페이스입니다.

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$attributeId = $_POST['attributeId'];

// 해당 사양 속성에서 SKU 정보를 쿼리
$ query = "SELECT skus.*, attribute.name 속성 FROM skus JOIN 속성 ON skus.attribute_id = attribute.id WHERE skus.attribute_id = '{$attributeId}'";
$result = $conn->query( $ 쿼리);

$skus = [];
while ($row = $result->fetch_assoc()) {

$skus[] = $row;

}

echo json_encode($skus);
}
?>

4 . 요약

이 글에서는 PHP를 사용하여 제품의 다중 사양 SKU 기능을 구현하는 방법을 소개합니다. 데이터베이스의 데이터 구조를 설계하고 백엔드 관리 페이지와 프런트엔드 상품 상세 페이지를 개발함으로써 판매자는 사양 속성과 SKU 정보를 유연하게 추가 및 편집할 수 있으며 소비자는 이를 기반으로 해당 SKU를 선택할 수 있습니다. 사양 속성. 이 기사가 전자상거래 플랫폼을 개발하는 독자들에게 영감을 주고 도움이 되기를 바랍니다.

위 내용은 PHP를 사용하여 제품 다중 사양 SKU 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.