使用MariaDB v. 10,我尝试在所有其他列*之前添加一个自定义常量作为SELECT查询的第一列。这将导致泛型语法错误1064。
例如:
# 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如果我只选择了一些列,它就能工作:
# 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 |
...如果我使用*选择所有列,但将常量列放在后面,它也能工作。
# mysql -u root -p$mypass -D mysql -e "SELECT *, 'X' FROM user;"
... [long, correct output] ...我如何做一个SELECT 'some constant', * FROM my_table来避免这个奇怪的错误?
发布于 2020-08-11 19:18:16
只有当SELECT *是SELECT列表中的第一件事时,才能使用它。如果它与其他值混合在一起,则需要使用表名或别名,所以要这样做
SELECT 'X', user.* FROM user;发布于 2020-08-11 19:18:08
对*使用表别名。我还将第一栏命名为:
SELECT 'X' as col, u.*
FROM user u;当MySQL与其他值一起选择时,它需要对*进行限定。
https://stackoverflow.com/questions/63364923
复制相似问题