首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL:不能在SELECT开头添加常量字段。错误1064

MySQL:不能在SELECT开头添加常量字段。错误1064
EN

Stack Overflow用户
提问于 2020-08-11 19:15:22
回答 2查看 79关注 0票数 0

使用MariaDB v. 10,我尝试在所有其他列*之前添加一个自定义常量作为SELECT查询的第一列。这将导致泛型语法错误1064。

例如:

代码语言:javascript
复制
# mysql -u root -p$mypass -D mysql -e "SELECT 'X', * FROM user;"
ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near '* FROM user' at line 1

如果我只选择了一些列,它就能工作:

代码语言:javascript
复制
# mysql -u root -p$mypass -D mysql -e "SELECT 'X', host, user FROM user;"
+---+-----------------+------------------+
| X | host            | user             |
+---+-----------------+------------------+
| X | 127.0.0.1       | root             |
| X | ::1             | root             |
...

如果我使用*选择所有列,但将常量列放在后面,它也能工作。

代码语言:javascript
复制
# mysql -u root -p$mypass -D mysql -e "SELECT *, 'X' FROM user;"  
... [long, correct output] ...

我如何做一个SELECT 'some constant', * FROM my_table来避免这个奇怪的错误?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-08-11 19:18:16

只有当SELECT *SELECT列表中的第一件事时,才能使用它。如果它与其他值混合在一起,则需要使用表名或别名,所以要这样做

代码语言:javascript
复制
SELECT 'X', user.* FROM user;
票数 3
EN

Stack Overflow用户

发布于 2020-08-11 19:18:08

*使用表别名。我还将第一栏命名为:

代码语言:javascript
复制
SELECT 'X' as col, u.*
FROM user u;

当MySQL与其他值一起选择时,它需要对*进行限定。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63364923

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档