首页 >数据库 >mysql教程 >考虑到多种翻译和潜在的语言差距,如何有效地从 MySQL 中的属性和翻译表中选择多个列?

考虑到多种翻译和潜在的语言差距,如何有效地从 MySQL 中的属性和翻译表中选择多个列?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-10-28 05:28:30757浏览

How can I efficiently select multiple columns from attribute and translation tables in MySQL, considering multiple translations and potential language gaps?

在 MySQL 子查询中选择多列

问题:

在 MySQL 数据库中,如何高效地选择多列从属性和翻译表中,考虑到每个属性都存在多种翻译,并且翻译可能不适用于所有情况下的所有语言?

答案:

推荐的方法是利用子查询在单个查询中检索多个列。关键是理解子查询可以通过将 select 语句括在括号中来充当虚拟表。

考虑以下查询:

<code class="sql">SELECT a.attr, b.id, b.trans, b.lang
FROM attribute a
JOIN (
    SELECT at.id AS id, at.translation AS trans, at.language AS lang, a.attribute
    FROM attributeTranslation at
) b ON (a.id = b.attribute AND b.lang = 1)</code>

在此查询中,括号中的 SELECT 语句创建一个虚拟表 b 包含翻译信息所需的列。然后将该虚拟表连接到真实的属性表 a,利用 ON 子句来匹配属性并按语言进行过滤。

通过以这种方式利用子查询,您可以有效地从单个表中选择多个列,确保返回所有属性,即使是没有指定语言翻译的属性。

替代方法:

或者,您可以为每列执行单独的子查询:

<code class="sql">SELECT a.attr, 
(select id from attributeTranslation where attribute=a.id and language=1),
(select translation from attributeTranslation where attribute=a.id and language=1), 
from attribute a;</code>

但是,这种方法通常效率较低,因为它需要多个子查询。

连接三个表(属性、属性语言和翻译)可能看起来是一个可行的解决方案,但通常会产生结果与使用子查询相比,性能较差。

以上是考虑到多种翻译和潜在的语言差距,如何有效地从 MySQL 中的属性和翻译表中选择多个列?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn