如何从 MySQL 子查询中检索多个列:虚拟表与 JOIN 语法?

Patricia Arquette
发布: 2024-10-27 09:52:03
原创
479 人浏览过

How to Retrieve Multiple Columns from a MySQL Subquery: Virtual Tables vs JOIN Syntax?

从 MySQL 子查询中选择多个列

在 MySQL 中,使用子查询从同一个表中检索多个列可能具有挑战性。为了解决这个问题,让我们探索不同的方法:

使用虚拟表

您可以使用子查询创建虚拟表,而不是创建多个子查询。此方法的语法为:

SELECT *
FROM (SELECT col1, col2, ... FROM original_table) AS virtual_table
登录后复制

通过在联接中使用此虚拟表,您可以在单个查询中从指定表中检索多个列。

代码示例:

SELECT a.attr, b.id, b.trans, b.lang
FROM attribute a
JOIN (
  SELECT id, translation AS trans, language AS lang, attribute
  FROM attributeTranslation
) AS b ON (a.id = b.attribute AND b.lang = 1)
登录后复制

使用 JOIN 语法

另一种选择是使用 JOIN 语法来组合多个表,包括原始表和虚拟表。这种方法允许您从连接的表中检索多列。

代码示例:

SELECT a.attr, b.id, b.trans, b.lang
FROM attribute a
JOIN attributeTranslation b ON (a.id = b.attribute AND b.lang = 1)
登录后复制

以上是如何从 MySQL 子查询中检索多个列:虚拟表与 JOIN 语法?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!