从 MySQL 中具有不等行的两个表中进行选择
在具有两个表(类别和产品)的在线购物数据库中,常见任务是检索所有类别以及每个类别中的最低和最高产品价格。然而,简单的查询会遇到一个问题:没有产品的类别被排除在结果之外。
要解决此挑战,有必要使用外连接而不是隐式连接。即使在另一表(产品)中没有相应的行,外连接也允许检索一个表(在本例中为类别)中的行。具体来说,这里使用左连接,以便所有类别都包含在结果中。
此外,为了将没有产品的类别的空值替换为 0,使用了 IFNULL() 函数。此函数采用第一个参数中提供的表达式的值,如果为 null,则返回第二个参数中指定的值。
更新的查询语法如下:
SELECT sc.*, IFNULL(MIN(s.price), 0) AS minp, IFNULL(MAX(s.price), 0) AS maxp FROM categories AS sc LEFT JOIN products AS s ON s.ownerid = sc.id GROUP BY sc.id
通过使用外连接和 IFNULL() 函数,我们可以检索所有类别,并确保没有产品的类别用 minp 和 maxp 值为 0 表示。此查询有效地处理了选择的需要来自两个表,即使一个表中并非所有行在另一个表中都有对应的条目。
以上是如何在 MySQL 中检索所有类别及其最低/最高产品价格,即使某些类别没有产品?的详细内容。更多信息请关注PHP中文网其他相关文章!