Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6207751
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T05:41:15+00:00 2026-05-24T05:41:15+00:00

I want to store the directories (present on the disk) into a database, maintaining

  • 0

I want to store the directories (present on the disk) into a database, maintaining their hierarchical/tree structure.

Here’s a figure:

                         (ROOT)
                       /        \ 
                    Dir2        Dir3
                   /    \           \
                 Dir4   Dir5        Dir6
                 /          
               Dir7

I am using the SQLite database.

Please suggest me:

  1. the SQL query to store above structure in SQLite database, and

  2. a query to retrieve full path of the directory when I select one.

    i.e. suppose I select Dir7 then I should get the full path like ROOT/Dir2/Dir4/Dir7

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T05:41:16+00:00Added an answer on May 24, 2026 at 5:41 am

    Here’s a quick closure table example for SQLite. I’ve not included the statements for inserting items into an existing tree. Instead, I’ve just created the statements manually. You can find the insert and delete statements in the Models for hierarchical data slides.

    For the sake of my sanity when inserting the IDs for the directories, I renamed the directories to match their IDs:

            (ROOT)
          /        \ 
        Dir2        Dir3
        /    \           \
      Dir4   Dir5        Dir6
      /          
    Dir7
    

    Create tables

    CREATE TABLE `filesystem` (
      `id` INTEGER,
      `dirname` TEXT,
      PRIMARY KEY (`id`)
    );
    
    CREATE TABLE `tree_path` (
      `ancestor` INTEGER,
      `descendant` INTEGER,
      PRIMARY KEY (`ancestor`, `descendant`)
    );
    

    Insert directories into filesystem table

    INSERT INTO filesystem (id, dirname) VALUES (1, 'ROOT');
    INSERT INTO filesystem (id, dirname) VALUES (2, 'Dir2');
    INSERT INTO filesystem (id, dirname) VALUES (3, 'Dir3');
    INSERT INTO filesystem (id, dirname) VALUES (4, 'Dir4');
    INSERT INTO filesystem (id, dirname) VALUES (5, 'Dir5');
    INSERT INTO filesystem (id, dirname) VALUES (6, 'Dir6');
    INSERT INTO filesystem (id, dirname) VALUES (7, 'Dir7');
    

    Create the closure table paths

    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 1);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 2);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 3);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 4);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 5);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 6);
    INSERT INTO tree_path (ancestor, descendant) VALUES (1, 7);
    INSERT INTO tree_path (ancestor, descendant) VALUES (2, 2);
    INSERT INTO tree_path (ancestor, descendant) VALUES (2, 4);
    INSERT INTO tree_path (ancestor, descendant) VALUES (2, 5);
    INSERT INTO tree_path (ancestor, descendant) VALUES (2, 7);
    INSERT INTO tree_path (ancestor, descendant) VALUES (3, 3);
    INSERT INTO tree_path (ancestor, descendant) VALUES (3, 6);
    INSERT INTO tree_path (ancestor, descendant) VALUES (4, 4);
    INSERT INTO tree_path (ancestor, descendant) VALUES (4, 7);
    INSERT INTO tree_path (ancestor, descendant) VALUES (5, 5);
    INSERT INTO tree_path (ancestor, descendant) VALUES (6, 6);
    INSERT INTO tree_path (ancestor, descendant) VALUES (7, 7);
    

    Run some queries

    # (ROOT) and subdirectories
    SELECT f.id, f.dirname FROM filesystem f
      JOIN tree_path t
        ON t.descendant = f.id
     WHERE t.ancestor = 1;
    
    +----+---------+
    | id | dirname |
    +----+---------+
    |  1 | ROOT    |
    |  2 | Dir2    |
    |  3 | Dir3    |
    |  4 | Dir4    |
    |  5 | Dir5    |
    |  6 | Dir6    |
    |  7 | Dir7    |
    +----+---------+
    
    
    # Dir3 and subdirectories
    SELECT f.id, f.dirname
      FROM filesystem f
      JOIN tree_path t
        ON t.descendant = f.id
     WHERE t.ancestor = 3;
    
    +----+---------+
    | id | dirname |
    +----+---------+
    |  3 | Dir3    |
    |  6 | Dir6    |
    +----+---------+
    
    # Dir5 and parent directories
    SELECT f.id, f.dirname
      FROM filesystem f
      JOIN tree_path t
        ON t.ancestor = f.id
     WHERE t.descendant = 5;
    
    +----+---------+
    | id | dirname |
    +----+---------+
    |  1 | ROOT    |
    |  2 | Dir2    |
    |  5 | Dir5    |
    +----+---------+
    
    # Dir7 and parent directories
    SELECT f.id, f.dirname
      FROM filesystem f
      JOIN tree_path t
        ON t.ancestor = f.id
     WHERE t.descendant = 7;
    
    +----+---------+
    | id | dirname |
    +----+---------+
    |  1 | ROOT    |
    |  2 | Dir2    |
    |  4 | Dir4    |
    |  7 | Dir7    |
    +----+---------+
    
    SELECT f.id, f.dirname
      FROM filesystem f
      JOIN tree_path t
        ON t.ancestor = f.id
     WHERE t.descendant = (
    SELECT id
      FROM filesystem
     WHERE dirname LIKE '%7%'
    );
    
    +----+---------+
    | id | dirname |
    +----+---------+
    |  1 | ROOT    |
    |  2 | Dir2    |
    |  4 | Dir4    |
    |  7 | Dir7    |
    +----+---------+
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I want to store a large number of sound files in a database, but
I want to store the data returned by $_SERVER[REMOTE_ADDR] in PHP into a DB
I want to store a large result set from database in memory. Every record
I want to store the current URL in a session variable to reference the
I want to store a a c# DateTimeOffset value in a SQL Server 2005
I want to store values in a bunch of currencies and I'm not too
I want to store a very large amount of vector data on a server
I want to store a URL prefix in an Windows environment variable. The ampersands
I want to store a list of the following tuples in a compressed format
I want to store a string in memory and read it later: $$->desc.constant->base.id =

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.