如何使用PHP開發簡單的投票系統與結果統計功能?
一、介紹:
投票系統是廣泛應用於各種場景的常見功能,例如企業員工評選、學生代表選舉等。本文將介紹如何使用PHP開發一個簡單的投票系統,並實現結果統計功能。
二、建置環境:
在開始之前,需要確保在本機或伺服器上已經安裝了PHP環境。如果沒有安裝,可以參考相關文件進行安裝設定。
三、資料庫設計:
在開始編寫程式碼之前,需要先設計資料庫表來儲存投票相關的資料。假設我們需要實作一個投票系統,其中涉及兩個表格:投票選項表(options)和投票結果表(votes)。
投票選項表(options):
#投票結果表(votes):
首先,我們需要在PHP中連接資料庫。建立一個名為"db_connect.php"的文件,並編寫以下程式碼:
<?php $servername = "localhost"; // 数据库服务器名称 $username = "root"; // 数据库用户名 $password = ""; // 数据库密码 $dbname = "vote_system"; // 数据库名 $conn = new mysqli($servername, $username, $password, $dbname); if ($conn->connect_error) { die("连接失败:" . $conn->connect_error); } ?>
建立投票選項:
<!DOCTYPE html> <html> <head> <title>投票系统</title> </head> <body> <h2>请选择您的投票选项:</h2> <form action="vote.php" method="post"> <?php require_once 'db_connect.php'; $sql = "SELECT * FROM options"; $result = $conn->query($sql); if ($result->num_rows > 0) { while ($row = $result->fetch_assoc()) { echo "<input type='radio' name='option_id' value='" . $row['id'] . "'>" . $row['option_name'] . "<br>"; } } $conn->close(); ?> <br> <input type="submit" value="提交"> </form> </body> </html>
<?php require_once 'db_connect.php'; $option_id = $_POST['option_id']; $voter_ip = $_SERVER['REMOTE_ADDR']; // 检查是否已经投过票 $sql = "SELECT * FROM votes WHERE voter_ip = '$voter_ip'"; $result = $conn->query($sql); if ($result->num_rows > 0) { echo "您已经投过票了!"; } else { // 更新投票选项的数量 $sql = "UPDATE options SET vote_count = vote_count + 1 WHERE id = $option_id"; $conn->query($sql); // 保存投票结果到数据库 $sql = "INSERT INTO votes (option_id, voter_ip) VALUES ($option_id, '$voter_ip')"; $conn->query($sql); echo "投票成功!"; } $conn->close(); ?>
<?php require_once 'db_connect.php'; $sql = "SELECT * FROM options"; $result = $conn->query($sql); if ($result->num_rows > 0) { while ($row = $result->fetch_assoc()) { echo $row['option_name'] . ":" . $row['vote_count'] . " 票<br>"; } } else { echo "暂无投票结果!"; } $conn->close(); ?>
以上是如何使用PHP開發簡單的投票系統和結果統計功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!