mysql视图创建细节1349错误

在开发中尝试创建一个包含子查询的视图时遇到1349错误,该错误提示视图的SELECT语句中不允许有FROM子句的子查询。回顾MySQL创建视图的规则,发现不能包含FROM后的子查询、引用系统或用户变量等。解决办法是将子查询单独创建为视图。此外,文章还提及了MySQL视图在性能上的局限,并提供了一个关于提升视图性能的文章链接。

        开发过程中写了一条sql,具体如下

select A.name,A.userid,D.orgname,IFNULL(B.bixiuCount,0),IFNULL(B.xuanxiuCount,0),IFNULL(C.gwBX,0),IFNULL(C.gwXX,0) from 
(select person.personid,person.name,users.userid,person.position,person.organizationid 
from t_hr_person person LEFT JOIN t_rights_user users on person.personid = users.personid 
WHERE person.isdelete=0 and users.isdelete=0) A LEFT JOIN
(select userid,
IFNULL(sum(case when(courseflag=0 ) then 1 else 0 end),0) bixiuCount,
IFNULL(sum(case when(courseflag=1 ) then 1 else 0 end),0) xuanxiuCount
from t_user_course where isdelete=0 
GROUP BY userid) B on A.userid = B.userid 
LEFT JOIN (
SELECT  GWC.dictionaryId dictionaryId,SUM(case WHEN (type=0) THEN 1 else 0 END) gwBX,SUM(case WHEN (type=1) THEN 1 else 0 END) gwXX
 FROM t_gwcourse GWC where GWC.isdelete=0
GROUP BY GWC.dictionaryId

) C ON C.dictionaryId=A.position

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值