Heim >Backend-Entwicklung >PHP-Tutorial >php 之 查询 投票练习(0508)

php 之 查询 投票练习(0508)

WBOY
WBOYOriginal
2016-07-29 08:50:411033Durchsuche

练习题目:

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教程有兴趣的朋友有所帮助。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn