>데이터 베이스 >MySQL 튜토리얼 >비디오와 같은 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?

비디오와 같은 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?

WBOY
WBOY원래의
2023-10-31 12:02:061065검색

비디오와 같은 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?

비디오와 같은 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?

Background
현대 소셜 미디어 플랫폼에서 좋아요는 사용자가 좋아하는 콘텐츠에 대한 승인과 지지를 표시하는 일반적인 방법입니다. 동영상 플랫폼의 경우 동영상 같은 기능을 구현하는 것이 매우 중요합니다. 이 기사에서는 기능과 같은 비디오를 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법을 소개하고 몇 가지 코드 예제를 제공합니다.

Design Ideas
MySQL 테이블 구조를 설계할 때 사용자, 동영상 및 좋아요 간의 관계 저장 방법, 좋아요 수 쿼리, 사용자가 좋아하는지 쿼리, 사용자가 좋아하는 비디오 쿼리 등의 측면을 고려해야 합니다. 사용자가 좋아요를 누른 것 등

  1. 사용자 테이블
    먼저 사용자 ID, 사용자 이름 등 사용자의 기본 정보를 저장하기 위한 사용자 테이블을 생성해야 합니다.

CREATE TABLE user (user (
id int(11) NOT NULL AUTO_INCREMENT,
username varchar(255) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

  1. 视频表
    其次需要创建一个视频表,用于存储视频的基本信息,如视频ID、视频标题等。

CREATE TABLE video (
id int(11) NOT NULL AUTO_INCREMENT,
title varchar(255) NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

  1. 点赞关系表
    接下来创建一个点赞关系表,用于存储用户对视频的点赞关系。每一条记录表示一个用户对一个视频的点赞操作。这个表需要包含用户ID和视频ID两个外键。

CREATE TABLE like_relation (
id int(11) NOT NULL AUTO_INCREMENT,
user_id int(11) NOT NULL,
video_id int(11) NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY user_video_unique (user_id,video_id),
CONSTRAINT like_user_fk FOREIGN KEY (user_id) REFERENCES user (id) ON DELETE CASCADE ON UPDATE CASCADE,
CONSTRAINT like_video_fk FOREIGN KEY (video_id) REFERENCES video (id id int(11) NOT NULL AUTO_INCREMENT,
username varchar(255) NOT NULL,

PRIMARY KEY (id)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

    Video table
      두 번째로, 영상의 기본 정보를 저장할 영상 테이블을 생성해야 합니다. , 동영상 ID, 동영상 제목 등

    1. CREATE TABLE video (
    2. id int(11) NOT NULL AUTO_INCREMENT,
      title varchar(255) NOT NULL,
    3. PRIMARY KEY (id)
    4. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
      1. Like 관계 테이블
      2. 다음으로, 동영상에 대한 사용자의 댓글을 저장하기 위해 Like 관계 테이블을 생성합니다. 관계. 각 기록은 동영상에 대한 사용자의 유사 작업을 나타냅니다. 이 테이블에는 사용자 ID와 비디오 ID라는 두 개의 외래 키가 포함되어야 합니다.
      3. CREATE TABLE like_relation (
        id int(11) NOT NULL AUTO_INCREMENT,
      4. user_id int(11) NOT NULL,
      video_id int(11) NOT NULL,

      PRIMARY KEY (id),
      UNIQUE KEY user_video_unique (user_id,video_id),

      CONSTRAINT like_user_fk FOREIGN KEY (user_id) REFERENCES user (id) ON CASCADE 업데이트 시 CASCADE 삭제,🎜 CONSTRAINT like_video_fk FOREIGN KEY (video_id) REFERENCES video (id) ON DELETE CASCADE ON UPDATE CASCADE🎜) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;🎜🎜코드 예제🎜 다음은 비디오 유사 함수를 구현하기 위해 일반적으로 사용되는 SQL 문입니다. 🎜🎜🎜동영상의 좋아요 수를 셉니다🎜SELECT COUNT(*) FROM like_relation WHERE video_id = 1;🎜🎜사용자가 동영상을 좋아하는지 쿼리🎜SELECT COUNT(*) FROM like_relation WHERE user_id = 1 AND video_id = 1; 🎜 🎜사용자가 좋아한 동영상 쿼리🎜like_relation에서 video_id 선택 WHERE user_id = 1;🎜🎜사용자가 동영상을 좋아합니다🎜INSERT INTO like_relation (user_id, video_id) VALUES (1, 1);🎜🎜사용자가 동영상 좋아요를 취소합니다🎜like_relation에서 삭제합니다 WHERE user_id = 1 AND video_id = 1;🎜🎜🎜요약🎜 비디오 유사 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하려면 사용자 테이블, 비디오 테이블, 유사 관계 테이블 및 일부 일반적인 SQL 문 설계를 고려해야 합니다. 관련 작업. 합리적인 테이블 구조 설계와 최적화된 쿼리문을 통해 유사 기능의 성능과 효율성을 향상시킬 수 있습니다. 🎜

    위 내용은 비디오와 같은 기능을 구현하기 위해 효율적인 MySQL 테이블 구조를 설계하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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