MySQL에서 쇼핑몰의 사용자 컬렉션 테이블 구조를 어떻게 디자인하나요?
몰 데이터베이스를 설계할 때 사용자 수집은 중요한 기능 중 하나입니다. 사용자는 관심 있는 상품을 즐겨찾기에 추가하여 나중에 쉽게 보거나 구매할 수 있습니다. 본 글에서는 MySQL에서 쇼핑몰의 사용자 컬렉션 테이블 구조를 설계하는 방법을 소개하고 구체적인 코드 예시를 제공합니다.
1. 요구 사항 분석
테이블 구조를 설계하기 전에 먼저 사용자 컬렉션의 요구 사항을 분석해야 합니다. 특히 다음 측면을 고려해야 합니다.
2. 테이블 구조 설계
위 요구 사항을 바탕으로 사용자가 선호하는 다음과 같은 테이블 구조를 설계할 수 있습니다.
CREATE TABLE user_favorite
(user_favorite
(
id
int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
user_id
int(11) NOT NULL COMMENT '用户ID',
product_id
int(11) NOT NULL COMMENT '商品ID',
add_time
datetime NOT NULL COMMENT '添加时间',
status
tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态,1表示有效,0表示无效',
PRIMARY KEY (id
),
KEY user_id
(user_id
),
KEY product_id
(product_id
)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户收藏表';
解释一下各个字段的含义:
三、代码示例
CREATE TABLE user_favorite
(
id
int(11) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
user_id
int(11) NOT NULL COMMENT '用户ID',
product_id
int(11) NOT NULL COMMENT '商品ID',
add_time
datetime NOT NULL COMMENT '添加时间',
status
tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态,1表示有效,0表示无效',
PRIMARY KEY (id
),
KEY user_id
(user_id
),
KEY product_id
(product_id
)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='用户收藏表';
INSERT INTO user_favorite
(user_id
, product_id
, add_time
)
VALUES (1, 1001, '2022-01-01 10:00:00');
SELECT product_id
, add_time
FROM user_favorite
WHERE user_id
= 1 AND status
= 1;
UPDATE user_favorite
SET status
= 0
WHERE user_id
= 1 AND product_id
id
int(11) ) NOT NULL AUTO_INCREMENT COMMENT '기본 키 ID',
user_id
int(11) NOT NULL COMMENT '사용자 ID', product_id
int(11) NOT NULL COMMENT 'product ID' ,
add_time
datetime NOT NULL COMMENT '시간 추가', status
tinyint(1) NOT NULL DEFAULT '1' COMMENT '상태, 1은 유효함, 0은 유효함을 의미 유효하지 않음' ,
PRIMARY KEY (id
),
user_id
(user_id
), KEY product_id
( product_id)
user_favorite
(🎜 id
int(11) NOT NULL AUTO_INCREMENT COMMENT '기본 키 ID ' ,🎜 user_id
int(11) NOT NULL COMMENT '사용자 ID',🎜 제품_ID
int(11) NOT NULL COMMENT '제품 ID',🎜 add_time datetime NOT NULL COMMENT '시간 추가',🎜 <code>status
tinyint(1) NOT NULL DEFAULT '1' COMMENT '상태, 1은 유효함, 0은 유효하지 않음',🎜 PRIMARY KEY ( id
),🎜 KEY user_id
(user_id
),🎜 KEY product_id
(product_id
)🎜 ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='사용자 즐겨찾기 테이블';🎜user_favorite
( user_id
, product_id
, add_time
) 🎜VALUES (1, 1001, '2022-01-01 10:00:00');🎜product_id
, add_time
FROM user_favorite
🎜WHERE user_id code > = 1 AND <code>status
= 1;🎜user_favorite
SET status = 0 🎜WHERE <code>user_id
= 1 AND product_id
= 1001;🎜🎜위 코드 예시는 사용자 수집 테이블 생성, 수집 기록 추가, 쿼리 방법을 보여줍니다. 사용자의 컬렉션을 기록하고 해당 상품의 즐겨찾기를 취소합니다. 🎜🎜요약: 🎜사용자 수집 테이블의 구조를 설계할 때 사용자 ID, 제품 ID, 시간 및 상태 추가와 같은 필드를 고려해야 합니다. 테이블 구조를 적절하게 설계하고 인덱스를 사용함으로써 데이터베이스의 쿼리 효율성을 향상시킬 수 있습니다. 동시에 실제 사용 시 비즈니스 요구에 따라 테이블을 최적화하고 확장할 수 있습니다. 🎜🎜참고: 위의 예제 코드는 참고용일 뿐이며 구체적인 구현은 실제 상황에 따라 조정되어야 합니다. 🎜
위 내용은 MySQL에서 쇼핑몰의 사용자 수집 테이블 구조를 어떻게 디자인하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!