在PostgreSQL中,ltree数据类型用于处理树形结构数据
创建表并添加ltree列:CREATE TABLE your_table_name ( id SERIAL PRIMARY KEY, path ltree);插入数据:INSERT INTO your_table_name (path) VALUES ('1');INSERT INTO your_table_name (path) VALUES ('1.2');INSERT INTO your_table_name (path) VALUES ('1.2.3');INSERT INTO your_table_name (path) VALUES ('1.3');INSERT INTO your_table_name (path) VALUES ('1.4');查询树形结构数据:获取所有子节点:SELECT * FROM your_table_name WHERE path ~ '^1\.2\..*';获取所有父节点:SELECT * FROM your_table_name WHERE path ~ '^1\..*';获取直接子节点:SELECT * FROM your_table_name WHERE path ~ '^1\.2\.\d+$';获取所有祖先节点:SELECT * FROM your_table_name WHERE path ~ '^1\.\d+\.\d+$';获取所有后代节点:SELECT * FROM your_table_name WHERE path ~ '^1\.\d+\.\d+$';获取指定节点的所有祖先节点:SELECT * FROM your_table_name WHERE path ~ '^' || '1.2.3' || '\.\d+$';获取指定节点的所有后代节点:SELECT * FROM your_table_name WHERE path ~ '^' || '1.2.3' || '\.\d+$';注意:在这些示例中,我们使用了~运算符来匹配路径列中的字符串模式。这是PostgreSQL中LIKE运算符的扩展版本,允许使用正则表达式。