数据库_Mysql _Every derived table must have its own alias 错误 子查询出来的表必须有一个临时表名

mysql执行多表查询时报错:

Sql代码   收藏代码
  1. [SQL] SELECT * from   
  2. (  
  3. select e.account from employee e  
  4. UNION  
  5. SELECT u.account from `user` u  
  6. UNION  
  7. SELECT a.account from agent a  
  8. )  
  9.   
  10. [Err] 1248 - Every derived table must have its own alias  

这句话的意思是每个派生出来的表必须有一个自己的别名

 

一般是在多表查询或者子查询的时候会出现这个错误,因为在嵌套查询中,子查询的结果是作为一个派生表给上一级进行查询,所以子查询的结果必须有一个别名。

 

上面的例子中,把查询语句修改一下:

Sql代码   收藏代码
  1. SELECT * from   
  2. (  
  3. select e.account from employee e  
  4. UNION  
  5. SELECT u.account from `user` u  
  6. UNION  
  7. SELECT a.account from agent a  
  8. )as total  

如上所示,在子查询的后面增加一句 as total,相当于给子查询的结果集派生表取别名为total,问题就解决了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值