如果Row1 = Value 1,则更新其他行

时间:2012-09-06 06:51:51

标签: php mysql json if-statement

我有一个小的PHP脚本转到mySql数据库。

我希望在数据库中插入新记录之前,如果数字(value1)等于数据库中的记录。 Wich也在Row1。

所以我想:

  • 查看输入的电话号码是否等于数据库中的电话号码。如果是这样,那么必须保持电话号码相同,只更新:经度,纬度&时间戳。
  • 如果电话号码等于null。不要将任何值放在我的数据库中。根本没有记录。
  • 如果电话号码不在数据库中,也什么都不做。重复它就像值为null一样。

这是我当前的PHP代码,我只是在有新值时创建新记录。

  <?php



$con = mysql_connect('server', 'user_name', 'pass');
if (!$con)
{
die('Could not connect: ' . mysql_error());
 }

mysql_select_db("db_name", $con);

if (isset($_REQUEST['data'])){
$json = $_REQUEST['data']; // recieve json from app
$data = json_Decode($json);

mysql_query("INSERT INTO test (id, longitude, latitude, timestamp) VALUES ('$data-   >id','$data->longitude','$data->latitude','$data->timestamp')"); 

}

mysql_close($con);
?>

如果有人能帮助我,我们将不胜感激!

感谢名单

2 个答案:

答案 0 :(得分:1)

您没有提到电话号码字段,因此我假设为phone_number

$db = new PDO('mysql:host=localhost;dbname=testdb;charset=UTF-8', 'username', 'password', array(PDO::ATTR_EMULATE_PREPARES => false, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));

if (isset($_REQUEST['data'])){
    $data = json_decode($_REQUEST['data']);
    if($data->phonenumber){
        $stmt = $db->prepare("SELECT `id` FROM `test` where `id`=:phone_number");
        $stmt->execute(array(':phone_number' => $data->phonenumber));
        $row_count = $stmt->rowCount();

        if($row_count && ($data->phonenumber != '')){
            $stmt = $db->prepare("UPDATE `test` SET `longitude`=:longitude, `latitude`=:latitude, `timestamp`=:timestamp WHERE `id`=:phone_number");
            $stmt->execute(array(':longitude' => $data->longitude,':latitude' => $data->latitude,':timestamp' => $data->timestamp,':phone_number' => $data->phonenumber));
        }
    }
}

答案 1 :(得分:0)

为什么要计算为特定电话号码计算的行数?只需检查$data->phone_number !== null,然后盲目执行更新查询

$stmt = $pdo->prepare('UPDATE table SET longitude = :longitude, latitude = :latitude, timestamp = :timestap WHERE id = :id');
if ($stmt->execute(array(':longitude' => $data->longitude,':latitude' => $data->latitude,':timestamp' => $data->timestamp,':id' => $data->phone_number)))
{
    echo 'Updated';
}
else
{
    echo 'Couldn\'t update';
}

或者更好的是:设置$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);并在try-catch块中更新,这样您就可以检查更新查询失败的原因并做出相应的响应。如果您的数据库引擎支持它,您可以在发生更新时使用$pdo->rollBack();,而不应该使用$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); try { $stmt = $pdo->prepare('UPDATE table SET longitude = :longitude, latitude = :latitude, timestamp = :timestap WHERE id = :id'); $stmt->execute(array(':longitude' => $data->longitude,':latitude' => $data->latitude,':timestamp' => $data->timestamp,':id' => $data->phone_number)); } catch(PDOException $e) { $pdo->rollBack();//undo any changes echo $e->getMessage(); }

{{1}}