집 >데이터 베이스 >MySQL 튜토리얼 >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>
이점
이 접근 방식에는 여러 가지 장점이 있습니다.
외래 키 제약 조건(선택 사항)
또한 외래 키 제약 조건을 추가하여 투표자 간의 참조 무결성을 강화할 수 있습니다. 테이블:
<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 중국어 웹사이트의 기타 관련 기사를 참조하세요!