- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想了解 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 .
最佳答案
简答:
到目前为止,我找到的关于此的唯一文档是: 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/
上下文:我已经在域根上设置了一个用于 GIS 测试和 dokuwiki 的虚拟机服务器。我想在子域上提供 gis Web 应用程序,这样 dokuwiki url 重命名就不会发生冲突(而且感觉更干净
这个问题在这里已经有了答案: If two variables point to the same object, why doesn't reassigning one variable affe
代码如下: Select Branch.BranchName, Sum(Inventory.OnHand) From Inventory, Branch Inventory.BranchNum = B
我的目标是创建一种“Javascript 库”,如果您可以这样调用它的话。我打算在浏览网页时使用它来操作页面,将其作为 greasemonkey 脚本动态加载。这个想法是将“win”映射到window
是否可以在 javascript 中以某种方式为本地变量分配别名/引用? 我的意思是类似 C 的东西: function foo() { var x = 1; var y = &x; y+
SQLite 别名 您可以暂时把表或列重命名为另一个名字,这被称为别名。使用表别名是指在一个特定的 SQLite 语句中重命名表。重命名是临时的改变,在数据库中实际的表的名称不会改变。 列别名用来
我有以下导入(在同一个 TS 源文件中): import {Vector as sourceVector} from "ol/source"; import {Vector} from "ol/lay
我想弄清楚 this 到底是什么行是在这个 github json 项目的 cmake 文件中, add_library(${NLOHMANN_JSON_TARGET_NAME} INTERFACE)
使用集合时如何创建别名 (AS)。 $collection->addAttributeToSelect('total_qty') 可以这样做: $collection->getSelect()->co
这个问题在这里已经有了答案: Pass an argument to a Git alias command (4 个回答) 去年关闭。 我的团队在不同的分支上工作,通常,我需要快速从分支切换来帮助他
我正在寻找一种向我的 vimrc 添加自定义命令或别名的方法,以便快速切换到 Vim 中的不同目录。我曾经设置过一些东西,但丢失了那个配置。这是用于 Linux 设置。 基本上,我想设置一个别名(如果
我使用 Delphi 和 Firebird 1.5 开发了一个应用程序,其中服务器与应用程序位于同一台计算机上。我现在正在将应用程序部署到另一个站点,其中 Firebird 服务器( super 服务
我创建了一个全新的 React 应用 create-react-app demo 我需要为某些目录/组件创建别名,例如: import { Header } from '@uicomponents'
我正在尝试打印有向图,并且不断更改各种节点属性,例如颜色和形状。有什么方法可以使用一次定义并用于多个节点的变量?理想情况下,我想要这样的东西: digraph g { building_color =
server { listen 80; server_name pwta; root html; location /test/{ alia
我想匹配多个数组,并在匹配时构建另一个数组。该键可以在任意数量的数组中匹配,也可以根本不匹配。 [ [{ 'a': 13 }, { 'b': 62 }, { 'c': 93 }, { 'd': 52
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我有一个这样的查询: select a1.name, b1.info from (select name, id, status from table1 a) as a1 righ
我想给一些 racket 2htdp 函数/宏起别名,这样我就可以为我的 child 将它们翻译成另一种语言。 我可以简单地用define给函数起别名。我在使用 big-bang 结构时遇到了麻烦;例
经过审查后,我需要更改一些代码并将所有更改代码重新推送到远程分支上。 所以我想使用别名(例如:git repushall)在 git 上自动化这些不同的命令: git add . git commit
我是一名优秀的程序员,十分优秀!