Maison >développement back-end >tutoriel php >php 之 查询 投票练习(0508)

php 之 查询 投票练习(0508)

WBOY
WBOYoriginal
2016-07-29 08:50:411028parcourir

练习题目:

php 之 查询 投票练习(0508)php 之 查询 投票练习(0508)php 之 查询 投票练习(0508)

解题:

方法一:

1. 投票主页面:



<meta http-equiv="Content-Type" c>
<title>投票</title>
<style>
#list
{
	width:400px;
	height:300px;}
#jieguo
{
	width:400px;
	height:300px;}
.x
{
	
	float:left;}

</style>




query($sql); $tmmc=$arr[0][1]; $tmdh=$arr[0][0]; echo "

{$tmmc}:

"; //从调研选项表中输出选项内容: $sqlxx="select * from diaoyanxuanxiang where timudaihao='{$tmdh}'"; $arrxx=$db->query($sqlxx); echo "
"; foreach ($arrxx as $v) { echo "
{$v[1]}

"; } ?> query($sqlzs); foreach ($arrxx as $v) { $name=$v[1]; $number=$v[2]; if($zrs[0][0]==0) { $bfb = 0; } else { $bfb = ($number/$zrs[0][0])*100; } $bfb=round($bfb,2); echo "
{$name} 
 
{$number}  {$bfb}% 

"; } ?>
<?php $arr=$_POST["xx"];
include ("../DBDA.class.php");
$db=new DBDA();


foreach($arr as $v)
{
	$sql = "update diaoyanxuanxiang set numbers = numbers+1 where ids = '{$v}'";
	$db->Query($sql,1);//1代表$sql的类型
}
header ("location:TouPiao.php");
?>

 3. 建立访问数据库的类,封装用于引用:

<?php //执行一个sql语句,返回相应的结果
class DBDA
{
	public $host="localhost";//数据库服务器地址
	public $uid="root";//数据库用户名
	public $password="";//数据库密码
	//执行SQL语句的方法
	//参数里面:$sql代表要执行的sql语句;$type是sql语句的类型,0代表查询,1代表其他(增删改);$db代表要操作的数据库
	function Query($sql,$type=0,$db="mydb")
	{
		//造连接对象
		$dbc MySQLi($this->host,$this->uid,$this->password,$db);
		//判断连接是否出错
		!mysqli_connect_error() or die("连接失败!");
		//执行sql语句
		$result=$dbconnect->query($sql);
		//判断SQL语句类型
		if($type==0)
		{
			 //如果是查询语句返回结果集的二维数组
			return $result->fetch_all();
			}
		else
		{
			//如果是其他语句,返回true或false
			return $result;
			}		
		}
		
	}

方法二:

1. 投票主页面:


<meta http-equiv="Content-Type" c>
<title>投票</title>
<style>
.x
{
	
	float:left;}

</style>




query($sql); $tmmc=$arr[0][1]; $tmdh=$arr[0][0]; echo "

{$tmmc}:

"; //从调研选项表中输出选项内容: $sqlxx="select * from diaoyanxuanxiang where timudaihao='{$tmdh}'"; $arrxx=$db->query($sqlxx); echo "
"; foreach ($arrxx as $v) { echo "
{$v[1]}

"; } ?>

 2. 处理投票页面:

<?php $arr=$_POST["xx"];
include ("../DBDA.class.php");
$db=new DBDA();


foreach($arr as $v)
{
	$sql = "update diaoyanxuanxiang set numbers = numbers+1 where ids = '{$v}'";
	$db->Query($sql,1);//1代表$sql的类型
}
header ("location:TouPiao.php");
?>

  3. 查看投票结果页面:



<meta http-equiv="Content-Type" c>
<title>查看结果</title>
<style>
.x
{
	float:left;}
</style>



<?php include ("../DBDA.class.php");
$db=new DBDA();
//从调研题目表中找出题目代号和名称
$sql="select * from diaoyantimu limit 0,1";
$arr=$db->query($sql);
$tmmc=$arr[0][1];
echo "<div><h2>{$tmmc}:</h2></div>";
//从调研选项表中输出选项内容:
$sqlxx="select * from diaoyanxuanxiang where timudaihao='{$arr[0][0]}'";
$arrxx=$db->query($sqlxx);

//计算总人数:
$sqlzs="select sum(numbers) from diaoyanxuanxiang where timudaihao='{$arr[0][0]}'";
$zrs=$db->query($sqlzs);

foreach ($arrxx as $v)
{
	 $name=$v[1];//调研项目名称
	 $number=$v[2];//选择该项的人数
	 //判断总人数是否为0
	 if($zrs[0][0]==0)
     {
         $bfb = 0;
     }
     else
     {
          $bfb = ($number/$zrs[0][0])*100;//求百分比
     }
	
	$bfb=round($bfb,2);	//取小数点后两位
	echo "<div>
	<span>{$name} </span>
	<div>
	<div> </div>
	</div>
	<span>{$number}  </span>
	<span>{$bfb}%</span><br>
	</div><br>";	
}
?>
<br>
<a href="TouPiao.php"><input type="button" value="返回"></a>


网页显示结果:

php 之 查询 投票练习(0508)php 之 查询 投票练习(0508)

以上就介绍了php 之 查询 投票练习(0508),包括了php,练习方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn