>데이터 베이스 >MySQL 튜토리얼 >MySQL에 배열을 저장하지 않고 다중 투표를 방지하는 방법은 무엇입니까?

MySQL에 배열을 저장하지 않고 다중 투표를 방지하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-30 11:32:26950검색

How to Prevent Multiple Voting without Storing Arrays in MySQL?

MySQL에 배열 저장: 다중 투표를 방지하기 위한 대체 접근 방식

MySQL은 기본적으로 필드 내 배열 저장을 지원하지 않습니다. 그러나 관계형 데이터베이스 설계를 사용하면 비슷한 결과를 얻을 수 있습니다.

데이터베이스 설계

다음 데이터베이스 스키마를 고려하세요.

<code class="sql">CREATE TABLE comments (
    comment_id INT PRIMARY KEY,
    body VARCHAR(100)
);

CREATE TABLE users (
    user_id INT PRIMARY KEY,
    username VARCHAR(20)
);

CREATE TABLE comments_votes (
    comment_id INT,
    user_id INT,
    vote_type INT,
    PRIMARY KEY (comment_id, user_id)
);</code>

comments_votes 테이블은 복합 기본 키를 사용하여 각 사용자가 주어진 댓글에 대해 한 번만 투표할 수 있도록 합니다.

예시 데이터

<code class="sql">-- Insert sample data
INSERT INTO comments VALUES (1, 'First comment');
INSERT INTO comments VALUES (2, 'Second comment');
INSERT INTO comments VALUES (3, 'Third comment');

INSERT INTO users VALUES (1, 'user_a');
INSERT INTO users VALUES (2, 'user_b');
INSERT INTO users VALUES (3, 'user_c');

-- Record user 1's votes
INSERT INTO comments_votes VALUES (1, 1, 1);
INSERT INTO comments_votes VALUES (2, 1, 1);</code>

이점

이 접근 방식에는 여러 가지 장점이 있습니다.

  • 다중 투표 방지: comments_votes 테이블의 기본 키 제약 조건은 참조 무결성을 강화하고 데이터 일관성을 보장합니다.
  • 유연한 투표 유형: vote_type 열은 좋아요 또는 싫어요와 같은 다양한 유형의 투표를 허용합니다.
  • 쉬운 쿼리: 관계형 모델 유권자 정보 및 투표 수에 대한 효율적인 쿼리가 가능합니다.

외래 키 제약 조건(선택 사항)

또한 외래 키 제약 조건을 추가하여 투표자 간의 참조 무결성을 강화할 수 있습니다. 테이블:

<code class="sql">CREATE TABLE comments (
    ...
) ENGINE=INNODB;

CREATE TABLE users (
    ...
) ENGINE=INNODB;

CREATE TABLE comments_votes (
    ...
    FOREIGN KEY (comment_id) REFERENCES comments (comment_id),
    FOREIGN KEY (user_id) REFERENCES users (user_id)
) ENGINE=INNODB;</code>

이 관계형 데이터베이스 설계를 활용하면 MySQL에 배열을 저장할 필요 없이 다중 투표를 효과적으로 방지하고 데이터 무결성을 유지할 수 있습니다.

위 내용은 MySQL에 배열을 저장하지 않고 다중 투표를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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