你把五個投票選項都添加到數(shù)據(jù)庫里面,然后還有一個字段是投票次數(shù),然后你從數(shù)據(jù)庫查詢五個選項每個選項的投票次數(shù),然后遍歷一下,用次數(shù)除以總投票次數(shù),就可以知道百分比了,然后你寫個css就可以顯示進度條了,或著用bootstrap的進度條,很簡單的
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),宣城企業(yè)網(wǎng)站建設(shè),宣城品牌網(wǎng)站建設(shè),網(wǎng)站定制,宣城網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,宣城網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。
對于剛學(xué)PHP和朋友來說是一個很不錯的入門程序。在這里給大家介紹一下,希望能對朋友們有所幫助。該系統(tǒng)是由以下四個文件組成的:有HTML調(diào)查表單的survey.htm,實現(xiàn)調(diào)查功能的survey.php,記錄調(diào)查項目的data.txt和記錄調(diào)查結(jié)果的survey.txt.其中data.txt和survey.txt我們可以用NOTEPAD分別創(chuàng)建之,并傳到程序目錄下。文件data.txt中存的是要進行調(diào)查的項目,注意每個項目應(yīng)占一行;而survey.txt則可以是一個什么內(nèi)容也沒有的空文件。Survey.htm的代碼可以如如下所示:html
head
titlesurvey/title
/head
body
form method="POST" action="survey.php"
pinput type="radio" value="0" name="vote"調(diào)查項目一/p
pinput type="radio" name="vote" value="1"調(diào)查項目二/p
pinput type="radio" name="vote" value="2"調(diào)查項目三/p
pinput type="radio" name="vote" value="3"調(diào)查項目四/p
pinput type="radio" name="vote" value="4"調(diào)查項目五/p
pinput type="hidden" name="go" value="1"
pinput type="submit" value="提交" name="B1"/p
a href="survey.php?result=1quo緝琺光貉叱股癸癱含凱t;查看結(jié)果/a
/form
/body
/html注意文件data.txt中的調(diào)查項目與上面的調(diào)查項目在個數(shù)和排列順序必須保持一致,否則會出錯或調(diào)查的結(jié)果不準(zhǔn)確。同時為了將調(diào)查結(jié)果顯示成條形圖形式,應(yīng)該準(zhǔn)備若干種不同顏色的條形圖片。如:0.gif,1.gif,2.gif,3.gif,4.gif等.以下是實現(xiàn)調(diào)查功能的survey.php代碼:?
$data="data.txt";
$votes="survey.txt";
$dataf=file( $data); /*讀出調(diào)查項目文件中的項目*/
$file_votes=fopen($votes, "r");
$line_votes=fgets($file_votes, 255); /*讀出已經(jīng)記錄的調(diào)查結(jié)果*/
fclose($file_votes);
$single_vote=explode("|", $line_votes); /* 并將數(shù)據(jù)按指定的字串切開,再將字串傳回到數(shù)組變量中 */
if ($result!=1) /*如果已經(jīng)接受了調(diào)查*/
{
$file_votes=file($votes, "r");
if ($REMOTE_ADDR == $file_votes[1]) /*檢查是不是同一個人*/
{
echo "centerfont color=red您已投過票了,謝謝您的參與!/font/center";
exit;
}
/*如果IP不重復(fù),則執(zhí)行以下程序*/
$ficdest=fopen($votes, "w");
for ($i=0; $i=count($dataf)-1; $i++)
{
if ($i == $vote)
{ /*判斷選擇了哪個項目*/
$single_vote[$i]+=1;
}
fputs($ficdest, "$single_vote[$i]|"); /*將數(shù)據(jù)寫回文件*/
}
fputs($ficdest, "\n$REMOTE_ADDR");/* //寫入投票者IP*/
fclose($ficdest);
$result=1; /*投票成功*/
}
/*寫入投票結(jié)果后并顯示投票結(jié)果*/
if ($result==1)
{
echo "table cellpadding=10";
for ($i=0; $i=count($dataf)-1; $i++)
{
/*取得投票總數(shù)*/
$tot_votes+=$single_vote[$i];
}
for ($i=0; $i=count($dataf)-1; $i++)
{
$imag=strval($i).".gif";/*判斷用哪種條形圖片來顯示統(tǒng)計結(jié)果*/
$stat[$i]=$single_vote[$i]/$tot_votes*100; /*計算百分比*/
$scla=$stat[$i]*5;/*條形圖和放大倍數(shù),這里是安百分?jǐn)?shù)的5倍的相素的寬度來顯示的*/
echo "trtdlifont face=Verdana size=2";
echo "$dataf[$i]/font/tdtd align=leftfont face=Verdana size=2";
echo "img src=\"$imag\" height=20 width=$scla align=middle ";/*輸出條形碼圖*/
printf("%.1f", "$stat[$i]");
echo "%/font/tdtd align=centerfont face=Verdana size=2";
/*輸出本欄目投票數(shù)*/
echo "$single_vote[$i]/font";
echo "/td/tr";
}
echo "/tablep";
echo "font face=Verdana size=2總投票數(shù):$tot_votes /font";
}
?說明: 在這里為了防止一人多投是采用記錄最近的一位投票者的IP的方法來實現(xiàn)的,而最近的一位投票的IP地址是WEB客戶機在對服務(wù)器發(fā)出請求時存儲在環(huán)境變量REMOTE_ADDR中的。我也是一個初學(xué)者,關(guān)于這篇文章可能有許多錯誤和不當(dāng)之處歡迎各位提出寶貴的意見和建議。
先設(shè)計表結(jié)構(gòu): 一個表用來記錄投票的題目,一個表用來記錄投票的人員、投哪一個標(biāo)題、投的好評差評等。 由于這兩個表屬于多對多關(guān)系,再建一個關(guān)系表??偣?張表。 再進行程序設(shè)計: 1、一個人對同一個標(biāo)題只能投一票。 2、程序能夠統(tǒng)計該題目的所有投票人員及其評價等級。 最后優(yōu)化數(shù)據(jù)庫: 要是你只想能用就行,這步就別做了。 要是構(gòu)建在大型網(wǎng)站上,要給表寫存儲過程、加索引。
滿意請采納
分享標(biāo)題:php投票系統(tǒng)數(shù)據(jù)庫,PHP投票系統(tǒng)
分享網(wǎng)址:http://aaarwkj.com/article36/dsigesg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、商城網(wǎng)站、外貿(mào)建站、自適應(yīng)網(wǎng)站、移動網(wǎng)站建設(shè)、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)