wy520cj 2009-10-29 12:26
浏览 174
已采纳

oracle查询

传入一个ID,表如下:
id,name,parentId,
查询在一条记录中是否有与之相关的子记录。
我写的语 句如下,但查不出来,不知道怎么修改为好,谢谢
select count(*) from MATERIAL_COLUMN where PARENT_COLUMN_ID in (SELECT ID FROM MATERIAL_COLUMN WHERE PARENT_COLUMN_ID=-1)
请问一下怎么修改为好呢。
[b]问题补充:[/b]
我需要的是得到父节点下的子节点和个数,在删除的时候好判断,如果父节点下面有子节点就不能删除,如果没有的话就可以删除。谢谢一楼的回答,但是SELECT count(*) FROM 表名 START WITH ID =#id:NUMERIC# CONNECT BY PARENT_COLUMN_ID= PRIOR ID查询出来后,删除子节点也会提得出一条数据。

  • 写回答

2条回答 默认 最新

  • CaiHuajiang 2009-10-29 13:35
    关注

    [quote] 2.查找一个节点的直属子节点(所有儿子)。 如果查找的是直属子类节点,也是不用用到树型查询的。
    Sql代码

    1. SELECT * FROM flfl WHERE sjflid = 819459;

    SELECT * FROM flfl WHERE sjflid = 819459;

      这个可以找到ID为819459的直属子类节点。
    
    
    
      3.查找一个节点的所有 直属子节点(所有后代)。
    

    Sql代码

    1. SELECT * FROM flfl START WITH ID = 819459 CONNECT BY sjflid = PRIOR ID;

    SELECT * FROM flfl START WITH ID = 819459 CONNECT BY sjflid = PRIOR ID;

      这个查找的是ID为819459的节点下的所有直属子类节点,包括子辈的和孙子辈的所有直属节点。[/quote]
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器