使用php插入多个数据以及在数据库中更新?

时间:2011-12-12 11:24:54

标签: php mysql

我使用google api从当前位置获取最近的50公里位置名称,所以它“运行正常。”

所以我需要将所有这些位置插入到我的数据库中。如果数据库中已有某个位置,我需要更新这些位置。

例如,我在google api中获得了10个位置,因此我的数据库中已有5个位置。我需要5个位置更新,其余5个位置都插入。

这是我的代码:

<?php
require 'dbconnect.php';
$LocaName=$_REQUEST['locname'];
$address=$_REQUEST['address'];
$latt=$_REQUEST['Latt'];
$long=$_REQUEST['Long'];

if($latt && $long)
{
    $LocaNamearray = explode("|||", $LocaName);
    $addressarray = explode("|||", $address);
    $lattarray=explode("|||",$latt);
    $longarray=explode("|||",$long);

    for($i=0;$i<count($lattarray);$i++)
    {
        $query1="select * from tbl_MapDetails where Latitude='".$lattarray[$i]."'and Longitude='".$longarray[$i]."'";
        $result1=mysql_query($query1);
        $now=mysql_num_rows($result1);
    }

    if($now >=1)
    {
        for($k=0;$k<count($lattarray);$k++)
        {
            $query="update tbl_MapDetails set LocationName='".$LocaNamearray[$k]."', Address='".$addressarray[$k]."',Latitude='".$lattarray[$k]."', Longitude='".$longarray[$k]."' where Latitude='".$lattarray[$k]."'and Longitude='".$longarray[$k]."'";
        }
        $nav="update";
    }
    else 
    {

        $query ="INSERT INTO tbl_MapDetails(LocationName,Address,Latitude,Longitude) VALUES";
        $strDelimiter = "";

        for($j=0;$j<count($LocaNamearray);$j++)
        {
            $name =$LocaNamearray[$j];
            $address =$addressarray[$j];
            $lat = $lattarray[$j];
            $long = $longarray[$j];
            $query .= $strDelimiter."('$name', '$address','$lat','$long')";
            $strDelimiter = ',';
        }
        $nav="Add";
    }

    $result= mysql_query($query);

    if($result)
    {
        echo mysql_error();
        $message=array("message"=>"sucessfully".$nav);
    }
    else
    {
        echo mysql_error();
        $message=array("message"=>"fail".$nav);
    }
}
else
{
    $message=array("message"=>"require latt and long");
}

echo json_encode($message);

?>

这里插入和更新工作,但我需要检查数据库中的每个位置。数据库中没有位置。它需要插入其他位置进行更新。如何检查这些条件匹配的位置是更新和不匹配的位置插入请指导我。

2 个答案:

答案 0 :(得分:1)

看看MySQL的ON DUPLICATE KEY UPDATE。但你必须小心,因为它的运行速度很慢。 但是,我认为,如果你只使用OR条件将所有SELECT请求合并在一起会更好。

答案 1 :(得分:1)

您的逻辑在代码中是错误的。您正在做的是循环提供的数据和每组数据检查是否存在具有该纬度/经度的位置并将其存储在$ now变量中。完成该循环后,您将立即检查$并再次循环提供的数据并插入或更新每组数据。因此,如果存在最后一组数据,您的脚本将尝试并更新每组数据。如果没有,您的脚本将尝试INSERT每组数据。你的代码应该是这样的(代码和伪代码的混合):

for($i=0;$i<count($lattarray);$i++)
{
    $query1="select * from tbl_MapDetails where Latitude='".$lattarray[$i]."'and Longitude='".$longarray[$i]."'";
    $result1=mysql_query($query1);
    $now=mysql_num_rows($result1);


    if($now >=1)
    {
        // update table with location details
    } 
    else
    {
        // insert location details into table
    }
}

如果这成为性能问题,您可以先查看检索所有SELECT数据,但如果您一次只处理10行,则应该没问题。

注意:根据$ _REQUEST数据的来源,您可能需要进行一些验证,即检查是否有匹配的lat / long / name / address详细信息。