3

我有一个关于在 MySQL 工作台中创建视图的询问。保存时出现错误:“视图的 SELECT 在 FROM 子句中包含子查询”。

这是我的声明的副本:

CREATE VIEW viewMorningReport AS 
select z.AllocationDate, z.LocationName, z.StationName, a.00000100, b.01000200, c.02000300  from
(SELECT DISTINCT AllocationDate, LocationName, StationName FROM satsschema.employeeslot
where LocationName = 'T2 PML'
and StationName is not null) z
left outer join 
(SELECT AllocationDate, LocationName, StationName, EmpName AS '00000100' FROM     satsschema.employeeslot
WHERE Assigned = true
and (EmpTime = '00:00:00' && EmpTime < '01:00:00')) a
on z.LocationName = a.LocationName and z.StationName = a.StationName
left outer join
(SELECT  AllocationDate, LocationName, StationName, EmpName AS '01000200' FROM    satsschema.employeeslot
WHERE Assigned = true
and (EmpTime = '01:00:00' && EmpTime < '02:00:00')) b
on a.LocationName = b.LocationName and a.StationName = b.StationName
left outer join
(SELECT  AllocationDate, LocationName, StationName, EmpName AS '02000300' FROM satsschema.employeeslot
WHERE Assigned = true
and (EmpTime = '02:00:00' && EmpTime < '03:00:00')) c
on b.LocationName = c.LocationName and b.StationName = c.StationName

知道哪里出了问题吗?

4

2 回答 2

2

正如官方文档所说

E.4。视图限制

(..)

子查询不能在视图的 FROM 子句中使用。

一种选择是为每个子查询创建一个视图。另一个,是修改你的视图,避免subquerysfrom子句中

于 2012-09-04T03:52:21.913 回答
0

您可以创建子查询的视图并在主视图中调用他

于 2013-12-17T10:35:11.403 回答