首页 > 数据库 > mysql教程 > 如何解决MySQL的'视图的SELECT在FROM子句中包含子查询”错误?

如何解决MySQL的'视图的SELECT在FROM子句中包含子查询”错误?

Patricia Arquette
发布: 2024-12-27 12:51:09
原创
679 人浏览过

How to Resolve MySQL's

解决“视图的 SELECT 在 FROM 子句中包含子查询”错误

使用包含 FROM 子句的查询创建视图时子句时,MySQL 可能会遇到一条错误消息,指出“视图的 SELECT 在 FROM 子句中包含子查询”。此错误表明 MySQL 不允许在视图定义的 FROM 子句中使用子查询。

错误详细信息

考虑以下示例:

create view view_credit_status as
(
  select credit_orders.client_id,
    sum(credit_orders.number_of_credits) as purchased,
    ifnull(t1.credits_used,0) as used
  from credit_orders
  left outer join (
    select * from (
      select credit_usage.client_id, sum(credits_used) as credits_used
      from credit_usage
      group by credit_usage.client_id
    ) as t0
  ) as t1 on t1.client_id = credit_orders.client_id
  where credit_orders.payment_status='Paid'
  group by credit_orders.client_id
);
登录后复制

此查询尝试创建一个名为 view_credit_status 的视图,其中包含 FROM 子句中的子查询。但是,MySQL 会引发“视图的 SELECT 在 FROM 子句中包含子查询”错误。

解决方案

要解决此问题,解决方法是创建单独的视图用于子查询并从主视图引用这些视图。操作方法如下:

  1. 为与积分使用相关的子查询创建一个名为 temp_view_used_credits 的视图:
create view temp_view_used_credits as
select credit_usage.client_id, sum(credits_used) as credits_used
from credit_usage
group by credit_usage.client_id;
登录后复制
  1. 创建主视图 view_credit_status使用 temp_view_used_credits view:
create view view_credit_status as
(
  select credit_orders.client_id,
    sum(credit_orders.number_of_credits) as purchased,
    ifnull(temp_view_used_credits.credits_used,0) as used
  from credit_orders
  left outer join temp_view_used_credits on temp_view_used_credits.client_id = credit_orders.client_id
  where credit_orders.payment_status='Paid'
  group by credit_orders.client_id
);
登录后复制

这种方法将子查询分离到一个单独的视图中,允许MySQL在主视图中引用它,而不会违反限制。

以上是如何解决MySQL的'视图的SELECT在FROM子句中包含子查询”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板