PHP로 구현된 다양한 투표 방식을 갖춘 온라인 투표 시스템
인터넷 시대의 도래와 함께 사람들의 참여와 의견 표현에 대한 요구는 점점 더 강력해지고 있습니다. 온라인 투표 시스템은 그룹의 의견을 수집하고 민주적인 의사결정을 달성할 수 있는 편리하고 빠른 방법이 되었습니다.
이 글에서는 PHP 언어를 기반으로 다양한 투표 방식을 갖춘 온라인 투표 시스템을 소개하고 관련 코드 예제를 제공하겠습니다.
vote
(id
int(11) NOT NULL AUTO_INCREMENT, title code> varchar(255 ) NOT NULL,<code>vote
(
id
int(11) NOT NULL AUTO_INCREMENT,
title
varchar(255) NOT NULL,
start_time
datetime NOT NULL,
end_time
datetime NOT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE option
(
id
int(11) NOT NULL AUTO_INCREMENT,
vote_id
int(11) NOT NULL,
content
text NOT NULL,
PRIMARY KEY (id
),
KEY vote_id
(vote_id
),
CONSTRAINT fk_vote_id
FOREIGN KEY (vote_id
) REFERENCES vote
(id
start_time
datetime NOT NULL,
end_time
datetime NOT NULL,
id
)옵션
(id
int(11) NOT NULL AUTO_INCREMENT,vote_id
int(11) ) NOT NULL, content
text NOT NULL,
PRIMARY KEY(id
),
KEY vote_id
(vote_id
) ),
CONSTRAINT fk_vote_id FOREIGN KEY (vote_id
) REFERENCES vote
(id
) ON DELETE CASCADE ON UPDATE CASCADE
프런트엔드 디자인
echo "<input type='".$vote['type']."' name='option' value='".$option['id']."'>".$option['content']."</input><br/>";
echo "";
백엔드 구현
// 투표 제출
if ($_SERVER['REQUEST_METHOD'] == 'POST') {$selectedOption = $_POST['option']; // 根据选项类型进行不同的处理 if ($vote['type'] == 'radio') { // 单选投票 $voteCount = 1; } elseif ($vote['type'] == 'checkbox') { // 多选投票 $voteCount = count($selectedOption); } elseif ($vote['type'] == 'rating') { // 打分投票 $totalRating = $_POST['total_rating']; $voteCount = 1; } // 更新选项表中的投票统计 foreach ($selectedOption as $optionId) { // 执行更新操作,计数+1 // UPDATE option SET count = count + 1 WHERE id = $optionId }
$votePercentage = ($option['count'] / $voteCount) * 100; echo $option['content'] . ": " . $votePercentage . "%<br/>";
위 내용은 PHP로 구현된 다양한 투표 방식을 갖춘 온라인 투표 시스템의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!