[Err] 1064 - mysql创建视图union all

[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;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

engr_chen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值