最近,我接手了一个二次开发的WEB系统,是springmvc的架构,但是,当我完成了某个子模块应用程序的开发,准备把源代码布置到系统上的时候,发现,无法生成主菜单下的子菜单。上图,给大家有一个形象地认识:
,然后,先前的那个开发团队,留下的数据库,里面有2个表专门是用来更新菜单节点的,例如,我想在主菜单Node1下,增加一个 Node1.1,我必须在menu表和privilige表里增加以下的SQL语句,
Insert into menu values (115, 'java books', 'java', 'Java编程语言', 'ajax', ' ',15, 7, ‘/books/page/javaBkMng’);
Insert into privilege p values (1000,115 );
这里的2张表结构分别是:
menu 表
id, app_key, menu_key, txt_local, txt_en, txt_fr, parent_id, position, url
privilige 表
id, menu_fk
我现在面临的困难就是,需要在这个菜单里添加一个带权限的子节点,根据遗留下来的源代码,以前的开发人员使用了with recursive cte as的递归查询,拼接SQL语句,来生成这个TREE形的菜单。
请问,我的数据库是ORACLE的,能使用with recursive cte as这样的语句吗?如果不行,用with cte(...) as可以吗?请指教如何写这段拼接SQL语句来实现这种JAVA代码自动扫描数据库表,生成新的带URL的节点,谢谢。