sql多重嵌套子查询,求优化!!!!!

selectMenuTextfrommainmenuwherePermissionIDin(selectdistinctPermissionIDfromRole_Perm... select MenuText from mainmenu where PermissionID in(
select distinct PermissionID from Role_Permission where RoleID
in (select RoleID from User_Roles where roleid
in (select RoleID from User_Roles where userid =
(select id from users where Account='seven'))))
展开
 我来答
xautwuyi
2012-06-20 · TA获得超过404个赞
知道小有建树答主
回答量:570
采纳率:0%
帮助的人:363万
展开全部
select mm.MenuText from
mainmenu mm,
Role_Permission rp,
user_roles ur,
users u
where mm.PermissionID = rp.PermissionID
and ur.roleid=rp.roleid
and ur.roleid=u.roleid
and Account='seven'
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
raymonshi
2012-06-20 · TA获得超过490个赞
知道小有建树答主
回答量:416
采纳率:100%
帮助的人:244万
展开全部
楼主对 user_roles的嵌套好象是重复了一遍,以下sql,请参考
SELECT MenuText
FROM mainmenu mu
WHERE PermissionID EXISTS
(SELECT 1
FROM Role_Permission rp
WHERE mu.PermissionID = rp.PermissionID
AND EXISTS (SELECT 1
FROM User_Roles ur
WHERE rp.RoleID = ur.userid
AND ur.account = 'seven'))
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wdjhz
2012-06-20 · TA获得超过3529个赞
知道大有可为答主
回答量:2227
采纳率:41%
帮助的人:670万
展开全部
select MenuText from mainmenu where PermissionID in(
select distinct PermissionID from Role_Permission where RoleID
in (select RoleID from User_Roles where userid =
(select id from users where Account='seven')))
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jiangjie_yahoo
2012-06-20 · TA获得超过151个赞
知道小有建树答主
回答量:235
采纳率:0%
帮助的人:49.9万
展开全部
应该可以用内连接 inner join。
mainmenu(PermissionID)--Role_Permission (PermissionID )
Role_Permission (RoleID )--User_Roles (roleid )
User_Roles (userid)--users (id )
where users .Account='seven'
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式