需要帮助来计算得分的赢利和亏损

马特·金恩

我正在用php创建一个网站来记录我学校的乒乓球成绩,目前获胜的玩家将登录WinnerID, LoserID, PointsFor, PointsAgainst我有两个具有以下关系的表。

表:用户

  • user_ID(PK)
  • 用户名
  • 链接

表:游戏

  • game_id(PK)
  • WinnerID(FK)
  • 失败者ID(FK)
  • 要点
  • 积分反对

我在php文件中的插入语句是:

INSERT INTO games(WinnerID,LoserID,PointsFor,PointsAgainst) VALUES('$Winner_ID','$Loser_ID','$userscore','$oppscore')"

这是我尝试过的方法,但是无法正确显示分数。

SELECT min(u.username) 'Username', COUNT(g.WinnerID) 'Wins', sum(g.PointsFor) 'Points For', sum(g.PointsAgainst) 'Points Against', u.Elo 'Ranking' 
from games g 
LEFT JOIN users u 
on g.WinnerID = u.user_id 
Group by g.WinnerID

这是select语句的输出

如上图所示,总计的点和相对于总计的点不累加。当前,它仅显示获胜者的统计信息。这意味着如果PlayerA赢得21-5,它将显示在选择语句中,但是PlayerB不会显示5-21的分数。任何帮助表示赞赏。

用于输入分数的页面的PHP代码:

if(isset($_POST['btn-post']))
{
    $opponent = $_POST["opponent"];
    //$opponent = array_key_exists('opponent', $_POST) ? $_POST['opponent'] : false;

    $userscore = mysql_real_escape_string($_POST['userscore']);
    $oppscore = mysql_real_escape_string($_POST['oppscore']);

    if($userscore != $oppscore)
    {
        if($userscore > $oppscore)
        {
            $Winner_ID = $_SESSION['user'];
            $query = mysql_query("SELECT user_id FROM users WHERE username = '".$opponent."'");
            $result = mysql_fetch_array($query) or die(mysql_error());
            $Loser_ID = $result['user_id'];

            $query1 = mysql_query("SELECT Elo FROM users WHERE user_id=".$_SESSION['user']);
            $result1 = mysql_fetch_array($query1) or die(mysql_error());
            $winnerRating = $result1['Elo'];

            $query2 = mysql_query("SELECT Elo FROM users WHERE user_id=".$Loser_ID);
            $result2 = mysql_fetch_array($query2) or die(mysql_error());
            $loserRating = $result1['Elo'];

            $rating = new Rating($winnerRating, $loserRating, 1, 0);            
            $results = $rating->getNewRatings();

            if(mysql_query("UPDATE users SET Elo = " . $results['a'] . " WHERE user_id=".$_SESSION['user']))
            {

            }
            else
            {
                ?>
                <script>alert('There was an error while entering winners(user) ranking...');</script>
                <?php
            }
            if(mysql_query("UPDATE users SET Elo = " . $results['b'] . " WHERE user_id=".$Loser_ID))
            {

            }
            else
            {
                ?>
                <script>alert('There was an error while entering losers(opp) ranking..');</script>
                <?php
            }

        }   
        elseif($oppscore > $userscore)
        {       
            $Loser_ID = $_SESSION['user'];
            $query = mysql_query("SELECT user_id FROM users WHERE username = '".$opponent."'");
            $result = mysql_fetch_array($query) or die(mysql_error());
            $Winner_ID = $result['user_id'];

            //get rating from user table in database

            $query1 = mysql_query("SELECT Elo FROM users WHERE user_id=".$_SESSION['user']);
            $result1 = mysql_fetch_array($query1) or die(mysql_error());
            $loserRating = $result1['Elo'];

            $query2 = mysql_query("SELECT Elo FROM users WHERE user_id=".$Loser_ID);
            $result2 = mysql_fetch_array($query2) or die(mysql_error());
            $winnerRating = $result1['Elo'];

            $rating = new Rating($winnerRating, $loserRating, 1, 0);            
            $results = $rating->getNewRatings();

            $results = $rating->getNewRatings();
            if(mysql_query("UPDATE users SET Elo = " . $results['b'] . " WHERE user_id=".$_SESSION['user']))
            {

            }
            else
            {
                ?>
                <script>alert('There was an error while entering losers(user) ranking...');</script>
                <?php
            }
            if(mysql_query("UPDATE users SET Elo = " . $results['a'] . " WHERE user_id=".$Winner_ID))
            {

            }
            else
            {
                ?>
                <script>alert('There was an error while entering winners(opp) ranking...');</script>
                <?php
            }

        }
        if(mysql_query("INSERT INTO games(WinnerID,LoserID,PointsFor,PointsAgainst) VALUES('$Winner_ID','$Loser_ID','$userscore','$oppscore')"))
        {
            ?>
            <script>alert('Your scores were successfully entered');</script>
            <?php
        }
        else
        {
            ?>
            <script>alert('There was an error while entering your score...');</script>
            <?php
        }
    }
    else
    {
        ?>
        <script>alert('There cannot be a tie in ping pong, please re-enter your scores...');</script>
        <?php
    }

}
?>
加布里埃尔·纳尼斯(Ghabriel Nunes)

您的查询失败,因为它没有考虑玩家输掉的行。您可以使用union来解决此问题以下查询应执行您想要的操作:

SELECT  username AS "Username",
    SUM(wins) AS "Wins",
    SUM(PF) AS "Points For",
    SUM(PA) AS "Points Against",
    elo AS "Ranking"
FROM (
    (SELECT users.user_ID,
            users.username AS username,
            COUNT(games.WinnerID) AS wins,
            SUM(games.PointsFor) AS PF,
            SUM(games.PointsAgainst) AS PA,
            users.Elo AS elo
    FROM users, games
    WHERE games.WinnerID = users.user_ID
    GROUP BY users.user_ID)
    UNION ALL
    (SELECT users.user_ID,
        users.username AS username,
        0 AS wins,
        SUM(games.PointsAgainst) AS PF,
        SUM(games.PointsFor) AS PA,
        users.Elo AS elo
    FROM users, games
    WHERE games.LoserID = users.user_ID
    GROUP BY users.user_ID)
) AS t
GROUP BY username
ORDER BY user_ID;

注意,在“失败查询”中,该字段PointsAgainst应与玩家的“得分”相反,反之亦然。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

需要帮助来影响标题和按钮

熊猫分组和计算得出的总和

DataFrame需要帮助来组织DF的列和行

需要帮助来区分模拟和测试驱动程序

需要帮助来理解C ++中的组成和类函数

BATCH需要帮助来替换文本和特殊字符

我需要帮助来反转chmod,chown和“ whoiam”代码

在JavaScript中需要帮助来更改和停止背景视频

XSLT需要帮助来转换XML以显示值和属性

在SQL Server中需要帮助以列出和计算动物的状态

我需要帮助在php和mysql中进行计算

需要帮助来编写查询

需要帮助来定制expandableListView

需要帮助来简化查询

C#和Javascript代码计算得出不同的结果

在Java程序上需要帮助来计算行星上的重量

初学者 JavaScript 我需要一些帮助来计算不同行的函数

需要帮助来计算ID在月份中重复出现的次数

需要Javascript计算表格帮助

需要帮助来对我的 MySQL 表中的时间和日期列进行排序

for循环c ++中的'冒号'和'自动'?需要一些帮助来理解语法

在 php 关联数组中需要帮助来替换键和值

C语言中的指针int,需要帮助来理解和简化代码段

需要Java算法的帮助来查找最大值和最小值

在使用键码39和37时,我需要帮助来移动div

我需要帮助来尝试理解有关结构和指针的这段代码

我需要帮助来创建构造函数并返回布尔值和字符串

需要帮助来识别ESAPI.validator()和ESAPI.encoder()之间的区别

流星反应搜索和显示onChange用户输入需要帮助来解决错误