MySQL에 배열 저장: 다중 투표를 방지하기 위한 대체 접근 방식
MySQL은 기본적으로 필드 내 배열 저장을 지원하지 않습니다. 그러나 비슷한 결과를 얻기 위해 관계형 데이터베이스 설계를 사용할 수 있습니다.
데이터베이스 설계
다음 데이터베이스 스키마를 고려하세요.
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)
);
comments_votes 테이블은 복합 기본 키를 사용하여 각 사용자가 주어진 댓글에 대해 한 번만 투표할 수 있도록 합니다.
예제 데이터
-- 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);
이점
이 접근 방식에는 여러 가지 장점이 있습니다.
외래 키 제약 조건(선택 사항)
또한 테이블 간의 참조 무결성을 강화하기 위해 외래 키 제약 조건을 추가할 수 있습니다.
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;
이 관계형 데이터베이스 설계를 활용하면 MySQL에 배열을 저장할 필요 없이 다중 투표를 효과적으로 방지하고 데이터 무결성을 유지할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3