[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘union all’
这个错误通常意味着 SQL 语句在 UNION ALL 附近存在语法错误。
如果未创建视图时可以进行查询,但是创建视图会提示1064异常,这就排除了:拼写时多余的字符错误、列数和类型不匹配、上下文错误等原因。
--原写法
CREATE VIEW V_BJCJJGXX AS (
SELECT t.xm_Name AS xmName,t.dept_Name AS deptName FROM online_bidding_head t
UNION ALL
SELECT t.AFFICHE_TIPIC AS xmName, t.dept_Name AS deptName FROM project_info t
);
--修改为
CREATE VIEW V_BJCJJGXX AS (
SELECT t.xm_Name AS xmName,t.dept_Name AS deptName FROM online_bidding_head t)
UNION ALL
(SELECT t.AFFICHE_TIPIC AS xmName, t.dept_Name AS deptName FROM project_info t
);
在原写法中,使用了括号将整个查询包围起来。这在某些 SQL 数据库中可能是允许的,但在 MySQL 中,使用括号来定义视图的 SELECT 语句时是有问题的。MySQL 不支持在视图定义中使用括号包围整个 SELECT 语句。
在修改后的写法中,第一个 SELECT 语句放在括号中,但将 UNION ALL 操作符放在了外部。这使得 MySQL 可以正确解析查询,这符合它的语法要求。
或者也可以直接去掉括号
CREATE VIEW V_BJCJJGXX AS
SELECT t.xm_Name AS xmName, t.dept_Name AS deptName FROM online_bidding_head t
UNION ALL
SELECT t.AFFICHE_TIPIC AS xmName, t.dept_Name AS deptName FROM project_info t;