简体   繁体   English

内部联接查询-3个表

[英]Inner Join Query - 3 tables

I am trying to execute this query to print data from three tables. 我正在尝试执行此查询以从三个表中打印数据。 But somehow the query is not being executed. 但是不知何故查询没有被执行。

SELECT l.locality_id, c.city_name, l.locality_name, cloud_site_location_outlet_localities.minimum_order, cloud_site_location_outlet_localities.delivery_time, cloud_site_location_outlet_localities.delivery_charge FROM `cloud_site_location_localities` l INNER JOIN `cloud_site_location_cities` c on l.city_id=c.city_id

The error that I get on executing above query is: 我在执行上述查询时遇到的错误是:

1054 - Unknown column 'cloud_site_location_outlet_localities.minimum_order' in 'field list'

However this query worked fine when I had to display data from two tables only. 但是,当我只需要显示两个表中的数据时,此查询工作正常。

SELECT l.locality_id, c.city_name, l.locality_name FROM `cloud_site_location_localities` l INNER JOIN `cloud_site_location_cities` c on l.city_id=c.city_id

Where am I going wrong? 我要去哪里错了?

When I use the following query to export it in CSV, I get redundant data. 当我使用以下查询将其导出为CSV格式时,我得到了冗余数据。 Out of 1000 entries, I only get 400 and then those 400 are repeated. 在1000个条目中,我只有400个,然后重复这400个。

This is code I am implementing 这是我正在实现的代码

$sql = "SELECT l.locality_id, c.city_name, l.locality_name, o.minimum_order, o.delivery_time, o.delivery_charge FROM `cloud_site_location_localities` l INNER JOIN `cloud_site_location_cities` c ON l.city_id = c.city_id INNER JOIN `cloud_site_location_outlet_localities` o ON l.locality_id = o.locality_id";
$result = $DB->query($sql);


//$output = fopen($filename, 'c+');
$output = fopen('php://output', 'c+');
fputcsv($output, array('Location Id', 'City Name', 'Location Name','Minimum Order Amount','Delivery Time','Delivery Charge'));
$row = array();
$csv_output = "";
$csv_output .= "Locality Id,City Name,Locality Name,Minimum Order Amount,Delivery Time,Delivery Charge\n";
foreach($result as $locality_value)
{
    $row['locality_id'] =   $locality_value->locality_id;
    $row['city_name']       =       $locality_value->city_name;
    $row['locality_name']   =   $locality_value->locality_name;
    $row['minimum_order']   =   $locality_value->minimum_order;
    $row['delivery_time']   =   $locality_value->delivery_time;
    $row['delivery_charge'] =   $locality_value->delivery_charge;
    $csv_output .= trim($row['locality_id']).",".trim($row['city_name']).",".trim($row['locality_name']).",".trim($row['minimum_order']).",".trim($row['delivery_time']).",".trim($row['delivery_charge']).",,\n";
    fputcsv($output, $row);

}
fclose($output);
print $csv_output;

You are missing the join clause for cloud_site_location_outlet_localities . 您缺少cloud_site_location_outlet_localitiesjoin子句。 Eg: 例如:

SELECT      l.locality_id, 
            c.city_name, 
            l.locality_name, 
            o.minimum_order, 
            o.delivery_time, 
            o.delivery_charge 
FROM       `cloud_site_location_localities` l 
INNER JOIN `cloud_site_location_cities` c 
        ON l.city_id = c.city_id
INNER JOIN `cloud_site_location_outlet_localities` o 
        ON l.outlet_id = c.outlet_id --just guessing the column names

simple structure for joining three tables in mysql 在mysql中联接三个表的简单结构

select *
from
    tbA a
        inner join
    tbB b
        on a.common = b.common
        inner join 
    tbC c
        on b.common = c.common

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM