我使用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);
?>
这里插入和更新工作,但我需要检查数据库中的每个位置。数据库中没有位置。它需要插入其他位置进行更新。如何检查这些条件匹配的位置是更新和不匹配的位置插入请指导我。
答案 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详细信息。