Home  >  Article  >  Database  >  How can I transform hierarchical database results into an array?

How can I transform hierarchical database results into an array?

Linda Hamilton
Linda HamiltonOriginal
2024-11-09 15:43:02514browse

How can I transform hierarchical database results into an array?

Converting Database Results into Arrays

To transform database results into an array while maintaining a hierarchical structure, consider employing a "Closure Table" approach. Here's how it works:

  1. Create a Closure Table: Establish a table that tracks hierarchical relationships, capturing the parent-child relationships between the data.
  2. Execute a SQL Query: Using an appropriate SQL statement, fetch the necessary data and parent relationships from the closure table.
  3. Recursive Data Processing: Perform recursive processing on the resultset. For each row, identify its parent and assign it to the "children" property of its parent.
  4. Convert to Array: The recursive processing enables the construction of a tree-like structure. Use the "toArrayDeep()" method to convert this structure into a plain array.
  5. Example:
// Fetch tree starting at Rodentia (id 180130), to a depth of 2
$tree = $tax->fetchTree(180130, 2);

// Dump out the array
var_export($tree->toArrayDeep());

This technique effectively organizes your data in a hierarchical manner, allowing for easy navigation and manipulation.

The above is the detailed content of How can I transform hierarchical database results into an array?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn