比较两个表的值和结果导出JSON



我有两个不同的表。对于那些i 选择一些结果。基于第一个基于最小/最大值,第二个基于LAT/LNG。这很容易(不要对这些值特别关注),并且由以下方式创建:

$sql1="SELECT * FROM events WHERE value BETWEEN '".$min2d."' AND '".$max2d."'";
$sql2="SELECT * FROM locations WHERE (lng BETWEEN ".$wl." AND ".$el.") AND (lat BETWEEN '".$sl."'AND'".$nl."')";

现在我们已经缩小了结果,我们要与第一个表格的第一个表>在第二个表上存在,将第一个表的'id' 匹配。关于成功,我们创建结果。

所以让我们先获取一些数字:

$result1 = mysql_query($sql1);
$result2 = mysql_query($sql2);
$numRows1 = mysql_num_rows($result1);
$numRows2 = mysql_num_rows($result2);
$loopCount1 = 1;
$loopCount2 = 1;

为了更有效地解析 JSON (来自用户),我们希望通过将其创建为JSON数组中的"持有人"来对事件进行排序。因此,这意味着,每个位置可能会有几个事件。

某些位置可能没有事件,但是某些事件可能与位置不符。我们唯一的比较方法是相同的'id'

通过我的以下尝试,这当然是为 all (这是错误的)位置而创建的,即使没有事件的人也会产生。这就是我需要您宝贵的帮助的地方。

$json = '{"markers":[';
while ($row2 = mysql_fetch_array($result2)){
    $json .= '{"coordinates": { "lat":'. $row2['lat'] .', "lng" : ' . $row2['lng'] .'},'
            .'{"events" : [';
    while ($row1 = mysql_fetch_array($result1)){
        if ($row1['id']=$row2['id'])
            $json .= '{ '   
                    .'"title": "'.$row1['title'].'",'
                    .'"info": "'.$row1['info'].'",'
                    .'"}';
        // add comma for Json if not final row
        if ($loopCount1 < $numRows1) {
            $json .= ', ';
            $loopCount1++;}
        }
    $json .= ']}}';
    // add comma for Json if not final row
    if ($loopCount2 < $numRows2) {
            $json .= ', ';
            $loopCount2++;}
    }
$json .= ']}';

最后一个回声:

echo $json;

要比较两个表的值并将结果打印为JSON,请使用以下代码,

<?php
      /* connect to the db */
      $link = mysql_connect('localhost','username','password') or die('Cannot connect to the DB');
      mysql_select_db('db_name',$link) or die('Cannot select the DB');
      /* grab the posts from the db */
      $query1 = "SELECT * FROM test1";
      $result1 = mysql_query($query1,$link) or die('Error query:  '.$query1);
      $query2 = "SELECT * FROM test2";
      $result2 = mysql_query($query2,$link) or die('Error query:  '.$query2);
      /* create one master array of the records */
      $posts = array();
      if(mysql_num_rows($result1) && mysql_num_rows($result2)) {
        while($post1 = mysql_fetch_assoc($result1)) {
            $post2 = mysql_fetch_assoc($result2);
            if($post1['name'] == $post2['name'])
              $posts[] = array('test1'=>$post1,'test2'=>$post2);
        }
      }
     header('Content-type: application/json');
     echo json_encode(array('posts'=>$posts));
      /* disconnect from the db */
      @mysql_close($link);
?>

相关内容

  • 没有找到相关文章

最新更新