> 데이터 베이스 > MySQL 튜토리얼 > MySQL의 식료품 쇼핑 시스템을 위한 분류 테이블 설계 기술

MySQL의 식료품 쇼핑 시스템을 위한 분류 테이블 설계 기술

WBOY
풀어 주다: 2023-11-01 09:42:18
원래의
1321명이 탐색했습니다.

MySQL의 식료품 쇼핑 시스템을 위한 분류 테이블 설계 기술

MySQL의 식품 쇼핑 시스템용 분류 테이블 설계 팁

소개:
식품을 구매하는 과정에서 분류는 매우 중요합니다. 식료품 쇼핑 시스템의 경우 분류 테이블 설계는 매우 중요한 단계입니다. 이 기사에서는 MySQL에서 식료품 쇼핑 시스템의 분류 테이블을 설계하는 기술을 소개하고 구체적인 코드 예제를 제공합니다.

1. 요구사항 분석
분류 테이블을 설계하기 전에 요구사항을 분석하고 분류의 계층 구조와 속성을 결정해야 합니다. 식품 쇼핑 시스템의 경우 고려할 수 있는 카테고리에는 재료, 접시, 주방 용품 등이 포함됩니다. 예를 들어, 재료는 야채, 과일, 고기 등으로 분류될 수 있습니다. 이를 바탕으로 분류 ID, 분류 이름, 상위 분류 ID 등과 같은 분류 테이블의 필드를 결정할 수 있습니다.

2. 디자인 카테고리 테이블

CREATE TABLE 카테고리 (
category_id INT(11) NOT NULL AUTO_INCREMENT,category_id INT(11) NOT NULL AUTO_INCREMENT,
category_name VARCHAR(50) NOT NULL,
parent_id INT(11) DEFAULT NULL,
PRIMARY KEY (category_id),
INDEX idx_parent_id (parent_id),
FOREIGN KEY (parent_id) REFERENCES category (category_id category_name VARCHAR(50) NOT NULL,
parent_id INT(11) DEFAULT NULL,

PRIMARY KEY (category_id),

INDEX idx_parent_id (parent_id),

FOREIGN KEY (parent_id) 참조 category (category_id)
    );
  • 설명:
  • category_id 필드는 카테고리의 고유 식별자로 사용됩니다. INT 유형을 사용하여 카테고리를 자동 증가 기본 키로 설정합니다.
  • category_name 필드는 VARCHAR 유형을 사용하여 50자 길이의 카테고리 이름을 저장하는 데 사용됩니다.
  • parent_id 필드는 INT 유형을 사용하여 상위 카테고리의 ID를 저장하는 데 사용되며 null 허용으로 설정됩니다. 첫 번째 수준 분류의 경우 parent_id는 NULL입니다.
  • 빠른 검색을 위해 Category_id 필드를 기본 키로 설정하세요.
상위 카테고리 ID를 기반으로 하위 카테고리를 빠르게 쿼리할 수 있도록 idx_parent_id 인덱스를 설정하세요.

상위 카테고리 ID의 유효성을 보장하기 위해 외래 키 제약 조건을 설정하세요.



3. 범주형 데이터 삽입

INSERT INTO 카테고리(category_name, parent_id) VALUES('ingredients', NULL);
INSERT INTO 카테고리(category_name, parent_id) VALUES('야채', 1);
INSERT INTO 카테고리( Category_name, parent_id) VALUES ('과일', 1);
INSERT INTO 카테고리 (category_name, parent_id) VALUES ('고기', 1);
INSERT INTO 카테고리 (category_name, parent_id) VALUES ('요리', NULL); INSERT INTO 카테고리 (category_name, parent_id) VALUES ('사천 요리', 5);
INSERT INTO 카테고리 (category_name, parent_id) VALUES ('광둥 요리', 5);
INSERT INTO 카테고리 (category_name, parent_id) VALUES ('후난 요리' , 5);
INSERT INTO 카테고리 (category_name, parent_id) VALUES ('주방 용품', NULL);

INSERT INTO 카테고리 (category_name, parent_id) VALUES ('도구', 9);

INSERT INTO 카테고리 (category_name, parent_id) VALUES ('Cookware', 9);

INSERT INTO Category (category_name, parent_id) VALUES ('Tableware', 9);
  • 참고:
  • 첫 번째 수준 카테고리의 데이터를 삽입할 때 parent_id는 다음으로 설정됩니다. 없는.

하위 카테고리의 데이터를 삽입할 때 parent_id는 해당 상위 카테고리 ID로 설정됩니다.

  1. 4. 카테고리 데이터 쿼리

모든 1차 카테고리 및 하위 카테고리 목록 쿼리:


SELECT p.category_name AS parent_category, c.category_name AS child_category

FROM 카테고리 p
    category LEFT JOIN c ON p . Category_id = c.parent_id
  1. WHERE p.parent_id IS NULL;

지정된 카테고리의 하위 카테고리 목록 조회:

  1. SELECT Category_name FROM 카테고리 WHERE parent_id = 1;

지정된 카테고리의 상위 카테고리 정보 조회 :


SELECT p.category_name AS parent_category, c.category_name AS child_category

FROM 카테고리 p

JOIN 카테고리 c ON p.category_id = c.parent_id
WHERE c.category_name = '야채';

Summary🎜V를 통해. 위의 디자인과 예제 코드를 통해 분류 기능을 갖춘 식료품 쇼핑 시스템을 구현할 수 있습니다. 분류표 디자인을 통해 다양한 재료, 식기, 주방용품 등을 유연하게 관리하고 정리할 수 있습니다. 이 기사가 MySQL에서 분류 테이블을 설계하는 데 몇 가지 참조와 도움을 제공할 수 있기를 바랍니다. 🎜

위 내용은 MySQL의 식료품 쇼핑 시스템을 위한 분류 테이블 설계 기술의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿