【问题标题】:PHP MySQL joining two tables with conditional joinsPHP MySQL 使用条件连接连接两个表
【发布时间】:2014-10-28 07:39:49
【问题描述】:

所以,我有一个正在创建的数据库。它存储有关家庭和每个家庭成员的信息。然后它使用这些记录将发票与家庭或家庭成员相关联。

我的困境是我需要将所有这些发票列出到家庭记录下的页面,即创建与家庭本身或单个家庭成员相关联的发票列表。

表结构

发票

id | date_entered | invoice_date | invoice_number | invoice_amount | client_type | unique_id | supplier_type | supplier_id | category_id | childcare_hours
---+--------------+--------------+----------------+----------------+-------------+-----------+---------------+-------------+-------------+----------------
1  | 1411098397   | 1411048800   | 123            | 0.01           | 0           | 137       | 0             | 139         | 5           | NULL

家庭

id |  ufi     |   last_name     | address_1   | address_2 | city_id | phone | mobile | email | f_d_worker_1 | f_d_worker_2 | status_id | trans_date | entry_date | exit_date | eligible_date | active_date | lga_loc_id | facs_loc_id | ind_status_id | referral_id | active_status | comm_org_id | notes
---+----------+-----------------+-------------+-----------+---------+-------+--------+-------+--------------+--------------+-----------+------------+------------+-----------+---------------+-------------+------------+-------------+---------------+-------------+---------------+-------------+-------
1  | 1-XEWUDZ | Forsyth - Ennis | Skinner St. | NULL      | NULL    | NULL  | NULL   | NULL  | 13           | NULL         | 1         | NULL       | 1341324000 | NULL      | 1341842400    | 1342620000  | 7          | 1           | 3             | NULL        | 1             | 1           | NULL

客户(家庭成员)

id |   upi    | last_name | first_name | birthdate  | sex | phone | mobile | email | indig_status_id | referral_id | relationship_id | preschool_id | family_id | notes
---+----------+-----------+------------+------------+-----+-------+--------+-------+-----------------+-------------+-----------------+--------------+-----------+------
 1 | 1-XFCBBP | Ennis     | Jason      | 20/09/1996 | 1   | NULL  | NULL   | NULL  | 3               | NULL        | NULL            | NULL         | 1         | NULL

我当前的 SQL 是这样的:

SELECT `invoices`.`id`, `invoices`.`date_entered`, `invoices`.`invoice_date`, `invoices`.`invoice_number`, `invoices`.`invoice_amount`, `invoices`.`client_type`, `invoices`.`unique_id`, `unique1`.`ufi`, `unique2`.`upi`, `unique1`.`last_name`, `invoices`.`supplier_type`, `invoices`.`supplier_id`, `suppliers`.`name`,  `invoices`.`category_id`, `cat1`.`name`, `cat2`.`name`, `invoices`.`childcare_hours` 
FROM `invoices` 
LEFT OUTER JOIN `suppliers` ON `suppliers`.`id` = `invoices`.`supplier_id` 
LEFT OUTER JOIN `categories` cat1 ON `cat1`.`id` = `invoices`.`category_id` 
LEFT OUTER JOIN `preschool_types` cat2 ON `cat2`.`id` = `invoices`.`category_id` 
LEFT OUTER JOIN `families` unique1 ON `unique1`.`id` = `invoices`.`unique_id` 
LEFT OUTER JOIN `clients` unique2 ON `unique2`.`id` = `invoices`.`unique_id` 
WHERE (`invoices`.`unique_id` = ? AND `unique1`.`ufi` = ?) LIMIT 0, 10

但是我需要一个查询来检查 client_type 列,如果它等于 1,它需要在 clients 表中查找,但它需要查找同一家族的成员,由 id 行中的families

解决方案

好的,所以经过很多(很多)搞砸和一点研究。看来@cupid 是正确的(尽管他的回答非常简短)。

我会更好地解释解决方案(希望这对以后的人有所帮助)。

MySQL(以及很可能是其他 SQL)中的 UNION 选项允许您将两个(或多个)SELECT 查询的结果集组合成一个结果集。如果您在单独的表格中拥有相似的数据,您可能希望轻松选择这些数据并将其作为一个请求处理,这将非常有用。通过允许您使用 SQL 的 LIMIT 选项,对分页也很有帮助(在我的情况下)。

需要考虑的一点是,UNION 语法使用第一个 SELECT 语句中的列作为所有后续查询的列名,您还需要确保在所有查询中选择相同数量的列让它工作。

(
    SELECT 
        `invoices`.`id`, 
        `invoices`.`date_entered`, 
        `invoices`.`invoice_date`, 
        `invoices`.`invoice_number`, 
        `invoices`.`invoice_amount`, 
        `invoices`.`client_type`, 
        `invoices`.`unique_id`, 
        `clients`.`upi`, 
        `clients`.`last_name`, 
        `clients`.`family_id`,
        `invoices`.`supplier_type`, 
        `invoices`.`supplier_id`, 
        `suppliers`.`name`, 
        `invoices`.`category_id`, 
        `cat1`.`name`, 
        `cat2`.`name`, 
        `invoices`.`childcare_hours` 
    FROM
    (
        `invoices` 
            LEFT OUTER JOIN `suppliers` ON `suppliers`.`id` = `invoices`.`supplier_id`
            LEFT OUTER JOIN `categories` cat1 ON `cat1`.`id` = `invoices`.`category_id`
            LEFT OUTER JOIN `preschool_types` cat2 ON `cat2`.`id` = `invoices`.`category_id`
            LEFT OUTER JOIN `clients` ON `clients`.`id` = `invoices`.`unique_id`)
        WHERE 
            `clients`.`family_id` = 47 AND `invoices`.`client_type` = 1
    )
UNION
( 
    SELECT 
        `invoices`.`id`,
        `invoices`.`date_entered`, 
        `invoices`.`invoice_date`, 
        `invoices`.`invoice_number`, 
        `invoices`.`invoice_amount`, 
        `invoices`.`client_type`, 
        `invoices`.`unique_id`, 
        `families`.`ufi`, 
        `families`.`last_name`,
        `families`.`id`,
        `invoices`.`supplier_type`, 
        `invoices`.`supplier_id`, 
        `suppliers`.`name`, 
        `invoices`.`category_id`, 
        `cat1`.`name`, 
        `cat2`.`name`, 
        `invoices`.`childcare_hours` 
    FROM `invoices`
        LEFT OUTER JOIN `suppliers` ON `suppliers`.`id` = `invoices`.`supplier_id` 
        LEFT OUTER JOIN `categories` cat1 ON `cat1`.`id` = `invoices`.`category_id`
        LEFT OUTER JOIN `preschool_types` cat2 ON `cat2`.`id` = `invoices`.`category_id`
        LEFT OUTER JOIN `families` ON `families`.`id` = `invoices`.`unique_id`
    WHERE 
        `invoices`.`unique_id` = 47 AND `invoices`.`client_type` = 0
)

【问题讨论】:

  • 我会使用更简单的查询,每个查询只做一件事,然后在 SQL 之外加入它们。
  • @VladGURDIGA 我更愿意将其用作一个查询,因为我需要计算分页函数的行数(也使用 SQL LIMIT)

标签: php mysql join


【解决方案1】:

您考虑过使用 UNION 吗?

【讨论】:

  • 你能给我举个例子吗?
  • SELECT data WHERE client_type = 0 UNION SELECT data JOIN family data here WHERE client_type = 1 w3schools.com/sql/sql_union.asp
  • 我已将您的答案标记为正确,尽管它非常简短。回答问题时,请尝试包含示例或某种参考。谢谢
  • 谢谢。我很高兴能以某种方式帮助你。对不起,简短的回答。我实际上刚刚开始在网站上回答。希望我能尽快适应海关。
猜你喜欢
  • 2012-04-27
  • 2015-12-07
  • 1970-01-01
  • 2021-11-10
  • 2017-02-15
  • 2016-11-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多