• Vlyn@lemmy.zip
    link
    fedilink
    arrow-up
    0
    ·
    3 months ago

    If you only join on indexed columns and filter it down to a reasonable number of results it’s easily fast enough.

    For true hierarchical structures there’s tricks. Like using an extra Path table, which consists of AncestorId, DescendentId and NumLevel.

    If you have this structure:

    A -> B -> C

    Then you have:

    A, A, 0

    A, B, 1

    A, C, 2

    B, B, 0

    B, C, 1

    C, C, 0

    That way you can easily find out all children below a node without any joins in simple queries.

    • ColonelThirtyTwo@pawb.social
      link
      fedilink
      arrow-up
      1
      ·
      3 months ago

      The fact that you’d need to keep this structure in SQL and make sure it’s consistent and updated kinda proves my point.

      It’s also not really relevant to my example, which involves a single level parent-child relationship of completely different models (posts and tags).