问题:
在 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中文网其他相关文章!