2 zv345653485 zv345653485 于 2013.12.18 12:51 提问

oracle start with 改成mysql

SELECT t.*
FROM (SELECT DISTINCT (sm.menu_id),
sm.up_menu_id,
sm.menu_name,
sm.menu_method,
sm.leaf,
sm.VALID_FLAG
FROM sys_menu sm,
sys_role_menu srm,
sys_role sr,
sys_user_role sur
WHERE sm.menu_id = srm.menu_id
AND srm.role_id = sr.role_id
AND sr.role_id = sur.role_id
AND sur.user_id = 3) t
START WITH t.up_menu_id = 999999
connect BY prior menu_id = t.up_menu_id

0 999999 系统管理
11 0 菜单管理
27 11 添加菜单操作
29 11 转到修改菜单页面
30 11 修改菜单操作
74 11 删除菜单操作
12 0 角色管理
24 12 转到修改角色
79 12 转到添加角色
80 12 添加角色操作
81 12 修改角色操作
107 12 删除角色操作
13 0 角色对应菜单
14 13 转到角色菜单绑定
25 13 角色绑定菜单操作
102 13 角色菜单删除操作

这是oracle 效果
现在要换成myslq 怎么写?

1个回答

a_liujian
a_liujian   2013.12.18 15:26

mysql我记得是没有递归函数的,帮你也查了下贴子,确实是没有,需要自已去写函数才行。

参考贴:
http://wangjinlongaisong-126-com.iteye.com/blog/1188907

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!