Задать вопрос
@df12

Как построить дерево?

Добрый день. Я новичок в PHP.

CREATE TABLE `groups` (
	`id` INT(11) NOT NULL AUTO_INCREMENT,
	`position` INT(11),
	`active` INT(11)
);

CREATE TABLE `methods` (
	`id` INT(11) NOT NULL AUTO_INCREMENT,
	`group_id` INT(11),
	`name` VARCHAR(255),
	`position` INT(11),
	`active` INT(11)
);


SQL запрос:
SELECT `methods`.* FROM `methods` LEFT JOIN `groups` ON `groups`.`id` = `methods`.`group_id` WHERE `methods`.`active` = 1 AND `groups`.`active` = 1 ORDER BY `methods`.`position`


Можно ли построить построить список ul, li?
<ul data-group_id="1">
	<li data-id="1">Name</li>
	<li data-id="2">Name</li>
</ul>
<ul data-group_id="2">
	<li data-id="4">Name</li>
	<li data-id="3">Name</li>
</ul>
  • Вопрос задан
  • 102 просмотра
Подписаться 1 Простой 3 комментария
Решения вопроса 1
rozhnev
@rozhnev Куратор тега PHP
Fullstack programmer, DBA, медленно, дорого
<?php
$query = 'SELECT
		`methods`.* 
	FROM `methods` 
	LEFT JOIN `groups` ON `groups`.`id` = `methods`.`group_id` 
	WHERE 
		`methods`.`active` = ? AND 
		`groups`.`active` = ? 
	ORDER BY `methods`.`group_id`, `methods`.`position`;';

// get DB version using PDO
$stmt = $pdo->prepare($query);
$stmt->execute([1, 1]);

if ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
	$group_id = $row['group_id'];
	
	printf(
		'<ul data-group_id="%d">' . PHP_EOL . '    <li data-id="%d">%s</li>' . PHP_EOL, 
		$group_id, $row['id'], $roe['name']
	);
	
	while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
		if ($group_id != $row['group_id']) {
			$group_id = $row['group_id'];
			printf(
				'</ul><ul data-group_id="%d">' . PHP_EOL, 
				$group_id
			);
		}
		printf('    <li data-id="%d">%s</li>' . PHP_EOL, $row['id'], $roe['name']);
	}
	
	printf('</ul>');
}


PHP Live test
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы