PHP更新基于其他表的表数据

时间:2012-08-27 15:05:58

标签: php mysql sql cron

我正在尝试创建一个cron作业,它将从事务表中选择点的总和。

根据积分和员工ID,我必须更新总积分表。 我想确保我使用最好的方法,这将有效。

 <?php

    $conn = mysql_connect("localhost", "mysql_user", "mysql_password");

    if (!$conn) {
        echo "Unable to connect to DB: " . mysql_error();
        exit;
    }

    if (!mysql_select_db("mydbname")) {
        echo "Unable to select mydbname: " . mysql_error();
        exit;
    }

    $sql = "SELECT ID, SUM(POINTS) as Points, FROM Transactions WHERE Status = 1 Group By ID";

    $result = mysql_query($sql);

    if (!$result) {
        echo "Could not successfully run query ($sql) from DB: " . mysql_error();
        exit;
    }

    if (mysql_num_rows($result) == 0) {
        echo "No rows found, nothing to print so am exiting";
        exit;
    }


    while ($row = mysql_fetch_assoc($result)) {  

    mysql_query("UPDATE Totals SET Points=" + $row["Points"] + "WHERE ID=" +  $row["id"]);

    }


    mysql_free_result($result);

    ?> 

2 个答案:

答案 0 :(得分:3)

您仍然可以在UPDATE语句上连接表(和子查询)。试试这个,

UPDATE Totals a 
        INNER JOIN
        (
            SELECT ID, SUM(POINTS) as Points, 
            FROM Transactions 
            WHERE Status = 1 
            Group By ID
        ) b
        ON a.ID = b.ID
SET a.Points = b.Points

希望这有帮助。

使用 PDO Extension (Code Snippet) 的示例。

<?php

$query = "UPDATE Totals a 
            INNER JOIN
            (
                SELECT ID, SUM(POINTS) as Points, 
                FROM Transactions 
                WHERE Status = ? 
                Group By ID
            ) b
            ON a.ID = b.ID
    SET a.Points = b.Points";

$iStatus = 1;
$stmt = $dbh->prepare($query);
$stmt->bindParam(1, $iStatus);

$stmt->execute();

?>

PDO Manual
PDO PreparedStatement

答案 1 :(得分:0)

为什么不能在通过cron作业运行之前测试脚本?我无法发现语法上的任何错误;但话又说回来,我只是快速浏览一下,我不知道你的桌子结构是什么样的。

如果您正在寻找最好的方法,那么您应该考虑使用mysqli或PDO而不是mysql函数。这样,您可以使用预准备语句,如果您计划在循环内运行多个查询,则不会对DBMS产生负担。准备好的语句不要求你单独往返服务器,而旧的mysql函数可以。