gpt4 book ai didi

mysql - 在 MySQL 中按别名选择列

转载 作者:搜寻专家 更新时间:2023-10-30 23:32:55 26 4
gpt4 key购买 nike

我想了解 MySQL 中的某些特定行为。运行“select @@version”,我看到我的版本是 5.6.34-log。

让我使用生成的表格放置示例,以便更容易重现:

SELECT 
CONCAT(a, b) AS 'c1', CONCAT((SELECT c1), 2)
FROM
(SELECT 'a', 'b', 'c' UNION ALL SELECT 1, 2, 3) t1;

我最初搜索的是,如标题所示,如何通过别名选择列,以便重用计算字段,避免长查询。大多数答案要么建议使用子查询或变量 - 一个可读性差,另一个不受自己的数据库开发人员的保证,如 documentation 中所述.然后,我从这个answer学到了这个方法, 并且不太理解 - 事实上,我什至不知道如何称呼这种操作/子句。

它似乎工作得很好,至少在这个 MySQL 版本中是这样。唯一的异常(exception)是当涉及到包含聚合函数的列时(如下所示)——它会抛出 1247(错误引用)错误,这感觉很合理。

-- THIS DOESN'T WORK!
SELECT
CONCAT(a, b) AS c1, CONCAT((SELECT c1), 2) as c2
FROM
(SELECT 'a' as a, 'b' as b, 'c' as c UNION ALL SELECT '1', 2, 3) t1;

我已经阅读了很多关于这个主题的答案,但这是对这种操作的唯一引用,而且,由于我不知道它的名字,我无法深入研究它。有谁知道这个结构是怎么叫的,我怎样才能更好地理解它?

编辑:我没有尝试执行无效查询中显示的操作。事实上,我正在尝试了解 MySQL 的行为。已经存在的问题足以理解如何使用子查询等来做到这一点——这不是重点。我的主要问题是了解 MySQL 在那里执行什么样的操作以及它是如何调用的,因为我从来没有读过任何类似的东西(它会是一个带有自动选择的查询吗?)

编辑 2:这篇文章启发了一个关于此 MySQL 行为的更具体和更好的书面问题,可以找到 here .

最佳答案

简答:

  1. 引用 SELECT 列表中的别名或
  2. 别名表达式

到目前为止,我找到的关于此的唯一文档是: https://bugs.mysql.com/bug.php?id=79549

在该链接中有以下内容:

[2015 年 12 月 9 日 15:35] Roy Lyseng...这是原始决定的较长背景:

与 WHERE 子句(以及 GROUP BY 中的子查询中的别名)相反,我们没有理由(标准合规性除外)不允许在子查询中引用别名SELECT 列表,因为它们应该在查询执行的同一阶段可用。但是 5.6 中的支持非常随意:

鉴于此:创建表 t1(a int, b int),

SELECT 列表中的别名无效:

  select a+b as c,c+1 from t1;

ERROR 1054 (42S22): Unknown column 'c' in 'field list'

但在子查询中,对 c 的引用是有效的:

  select a+b as c,(select c+1) from t1;

子查询必须在别名定义之后:

  select (select c+1),a+b as c from t1;

ERROR 1247 (42S22): Reference 'c' not supported (forward reference in item list)

因此,很容易说对在 SELECT 列表中引用别名 的支持是相当临时的。尽管如此,我们将尝试重新实现旧的解决方案,但不会尝试清理支持此功能的明显漏洞。但不会重新实现 WHERE 子句中子查询中的引用别名。

除了在标准文档中描述此功能的错误报告之外,我还在寻找文档;但到目前为止还没有运气。

关于mysql - 在 MySQL 中按别名选择列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46791808/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com