陈长瓦 2022-10-14 22:00 采纳率: 0%
浏览 147
已结题

mysql sql语句变量问题

SQL语句如下

SELECT ( @c:=s.id) as 'iid',
 (
    select f._id  from (SELECT @c as '_id',(select @c :=parent_id from sys_menu where id = @c) as 'pt'
     from sys_menu sy) f  where f.pt=0
 ) as 'parent'
 from   (select *  from sys_menu where id in(7,8,11)) s;
**
---结果中parent 应该为 1,2,3 ,返回的是1,1,1,不知道问题在哪里**


 #子语句运行结果
 set @c:=5;
 select f._id  from (SELECT @c as '_id',(select @c :=parent_id from sys_menu where id = @c) as 'pt'
    from sys_menu sy) f  where f.pt=0  
 ----结果为1

数据库中的数据如下

id parent_id
1 0
2 0
3 0
5 1
6 1
7 1
8 2
9 2
10 2
11 3
12 3
13 3
14 13
15 13
16 13

  • 写回答

5条回答 默认 最新

  • 心寒丶 全栈领域优质创作者 2022-10-15 10:31
    关注
    获得7.50元问题酬金

    要显示子父级,你直接查表就可以显示,如果要显示递归的层级,那你直接用 with recursive temp就能查所有的啊

    with recursive temp as (
    select * from sys_menu p  
    union all 
     select t.* from sys_menu t inner join temp t2 on t2.id = t.parent_id 
    )
    select *  from temp 
    
    

    img

    with recursive temp as (
    select * from sys_menu p where p.id in (7,8,11) 
    union all 
     select t.* from sys_menu t inner join temp t2 on t2.id = t.parent_id 
    )
    select *  from temp 
    
    

    img

    评论

报告相同问题?

问题事件

  • 系统已结题 10月22日
  • 创建了问题 10月14日

悬赏问题

  • ¥15 eda:门禁系统设计
  • ¥50 如何使用js去调用vscode-js-debugger的方法去调试网页
  • ¥15 376.1电表主站通信协议下发指令全被否认问题
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥15 复杂网络,变滞后传递熵,FDA
  • ¥20 csv格式数据集预处理及模型选择
  • ¥15 部分网页页面无法显示!
  • ¥15 怎样解决power bi 中设置管理聚合,详细信息表和详细信息列显示灰色,而不能选择相应的内容呢?
  • ¥15 QTOF MSE数据分析
  • ¥15 平板录音机录音问题解决