先設(shè)計表結(jié)構(gòu): 一個表用來記錄投票的題目,一個表用來記錄投票的人員、投哪一個標(biāo)題、投的好評差評等。 由于這兩個表屬于多對多關(guān)系,再建一個關(guān)系表??偣?張表。 再進(jìn)行程序設(shè)計: 1、一個人對同一個標(biāo)題只能投一票。 2、程序能夠統(tǒng)計該題目的所有投票人員及其評價等級。 最后優(yōu)化數(shù)據(jù)庫: 要是你只想能用就行,這步就別做了。 要是構(gòu)建在大型網(wǎng)站上,要給表寫存儲過程、加索引。
目前創(chuàng)新互聯(lián)公司已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站托管運營、企業(yè)網(wǎng)站設(shè)計、古田網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
滿意請采納
這是一個簡單的投票程序,對于剛學(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中存的是要進(jìn)行調(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=1"查看結(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ù)據(jù)庫是從數(shù)據(jù)庫調(diào)取的,然后你可以在數(shù)據(jù)庫中設(shè)計一個唯一ID字段自增行,然后通過GET方式傳遞數(shù)據(jù)查詢出信息,修改就很容易了吧