计算两个地方之间的距离&将结果插入到新表中


calculate distance between 2 places & insert the results to new tables

我有一个表单,要求用户输入他们的姓名,地址,&以学历模糊分析。当他们按下"标记位置"按钮时,它会在屏幕上显示他们的确切纬度& &;经度。在那之后,我想使用最后的&他们必须计算与mysql中已经存在的一些位置的距离(包括纬度&地点的经度)。

"标记位置"工作正常,但"保存"按钮似乎不计算距离&没有保存到2个新表,我已经有了(tj_masjid &tj_univ)。下面是我的代码:

<?php
    include 'connect.php';
    $conn = mysql_connect($dbhost,$dbuser,$dbpass);
    $db = mysql_select_db($dbname);
    if($_POST["button"]=="Save")
{
    $nama=$_POST["nama"]; //name
    $alamat =$_POST["alamat"]; //address
    $pendidikan =$_POST["pendidikan"]; //educational background (years)
    $latitude=$_POST["latitude"];
    $longitude=$_POST["longitude"];
    $query="INSERT INTO lokasi(nama, alamat, pendidikan, latitude, longitude) VALUES('$nama', '$alamat', '$pendidikan', '$latitude', '$longitude')"; //insert to table location
    $result=mysql_query($query);          
    if($result){
        echo "data berhasil disimpan"; //saving success
        $id_lokasi=mysql_query('SELECT id from lokasi where nama=nama, alamat=alamat, pendidikan=pendidikan, latitude=latitude, longitude=longitude');
    }else{
        echo "data gagal disimpan"; //saving failed
    }
    //calculate distance in kilometers
    function getDistanceBetween($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') 
{ 
    $theta = $longitude1 - $longitude2; 
    $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2)))  + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); 
    $distance = acos($distance); 
    $distance = rad2deg($distance); 
    $distance = $distance * 60 * 1.1515; 
    switch($unit) 
    { 
        case 'Mi': break; 
        case 'Km' : $distance = $distance * 1.609344; 
    } 
    return (round($distance,2)); 
}
    //calculate the distance between users location & masjid location (2 masjid)
    $sql_masjid=mysql_query("SELECT * from masjid");
    while($rs = mysql_fetch_array($sql_masjid, MYSQL_ASSOC)) {
        $masjid[$rs['id']] = $rs;
        $j_masjid[$rs['id']] = getDistanceBetween($latitude,$longitude,$rs['latitude'],$rs['longitude'],'Km');
        $t_jarak = $j_masjid[$rs['id']];
        $t_idmasjid = $rs['id'];
        $tj_masjid=mysql_query("INSERT INTO tj_masjid(id_lokasi, id_masjid, jarak) VALUES($id_lokasi,$t_idmasjid,$t_jarak)");       
    }
    //calculate the distance between users location & university location (2 univ)
    $univ=mysql_query("SELECT * from universitas");
    while($rs = mysql_fetch_array($univ, MYSQL_ASSOC)) {
        $univ[$rs['id']] = $rs;
        $j_univ[$rs['id']] = getDistanceBetween($latitude,$longitude,$rs['latitude'],$rs['longitude'],'Km');
        $t_jarak = $j_univ[$rs['id']];
        $t_iduniv = $rs['id'];
        $tj_univ=mysql_query("INSERT INTO tj_univ(id_lokasi, id_univ, jarak) VALUES($id_lokasi,$t_iduniv,$t_jarak)");
    }
}

首先,SQL查询中的所有php变量都应该在引号内。即$tj_univ=mysql_query("INSERT INTO tj_univ(id_lokasi, id_univ, jarak) VALUES('$id_lokasi','$t_iduniv','$t_jarak')");

其次,您没有在代码的任何地方定义$id_lokasi。