php手机投票源码,php投票系统简单实现源码(1/3)_PHP教程

require_once ‘OperatorDB.php’;

class OperatorVotingDB

{

private $odb;

public function __construct()

{

$this->odb = new OperatorDB();

}

public function __destruct()

{

$this->odb = null;

}

/**

* 清空Voting数据中的所有表

*

* 调用数据库操作类,执行clear数据库的操作

*/

public function clearTables()

{

$sqls = array(“TRUNCATE ip_votes;”,”TRUNCATE count_voting;”);

$this->odb->exec($sqls[0]);

$this->odb->exec($sqls[1]);

}

/**

* 重置count_voting表中的CountValues字段为0

*

*/

public function resetCountValues()

{

$sql = “UPDATE count_voting SET CountVotes = 0;”;

$this->odb->exec($sql);

}

/**

* 投票

* 将信息写入ip_votes表

* @param type $ip

* @param type $loc

* @param type $time

* @param type $name

*/

public function vote($ip,$loc,$name)

{

$sql = “INSERT INTO ip_votes VALUES (NULL, ‘$ip’, ‘$loc’, NOW(), ‘$name’)”;

$subsql = “SELECT MAX(to_days(VoteTime)) FROM ip_votes WHERE IP=’$ip'”;

$stm = $this->odb->query($subsql);

if (count($row=$stm->fetchAll())==1)

{

$now = date(“Y-m-d H:i:s”);

$subsql = “SELECT to_days(‘$now’);”;

$stm = $this->odb->query($subsql)->fetch();

$time = $stm[0];//使用mysql计算出的today时间

// echo $time.”

“;

// echo $row[0][0];

if ($time-$row[0][0]<1) 表中最大的时间和现在的时间$time比较

{

echo “投票失败,相同ip需要隔一天才能投票”;

return;

}

}

// echo $sql;

echo “投票成功!”;

$this->odb->exec($sql);

}

/**

* 添加SelectName字段的行

*

* @param string $name

* @param string $label

* @param int $count

*/

public function addSelectName($name, $label, $count=0)

{

$sql = “INSERT INTO count_voting VALUES (‘$name’, ‘$label’, $count);”;

$this->odb->exec($sql);

}

/**

* 获取总投票情况,按票数排序的结果

*

* 按CountVotes字段排序,返回count_voting表

*

* @param int $n

*

*/

public function getVotesSortByCount($n=-1)

{

$sql = “SELECT * FROM count_voting ORDER BY CountVotes DESC LIMIT 0 , $n;”;

if (-1 == $n)

{

$sql = “SELECT * FROM count_voting ORDER BY CountVotes DESC;”;

}

// echo $sql;

return $this->odb->query($sql);

}

/**

* 获取投票情况,按票数排序并按标签分组的结果

*

* 按CountVotes字段排序并按LabelName字段分组,返回count_voting表

*/

public function getVotesGroupByLabel()

{

$sql = “SELECT * FROM count_voting ORDER BY LabelName DESC;”;

// echo $sql;

return $this->odb->query($sql);

}

}

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值