Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.84/19: Рейтинг темы: голосов - 19, средняя оценка - 4.84
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557

Правильная организация древовидного меню

08.04.2014, 13:02. Показов 4164. Ответов 25
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Нужно организовать древовидное меню. Собственно говоря вот такого вида должна быть таблица:
Code
1
2
3
4
5
6
7
8
9
10
|id|Semestr|Predmet| Group |
| 1|    7  |   МО  | 7-78-5|
| 2|    7  |   МО  | 7-78-6|
| 3|    7  |   МО  | 7-78-7|
| 4|    8  |  ПР.Л | 8-78-5|
| 5|    8  |  ПР.Л | 8-78-6|
| 6|    8  |  ПР.Л | 8-78-7|
| 7|    3  | ПнаЯВУ| 3-78-5|
| 8|    3  | ПнаЯВУ| 3-78-6|
| 9|    3  | ПнаЯВУ| 3-78-7|
И вот так выводить все:
Сайт


Пока что получилось сделать только через parents
Через такую таблицу все удается сделать


НО, потом возникают проблему для условий изменения выборки главной таблицы (видно на первом скриншоте). Собственно по этому нужно сделать так, как написано в самом начале...

Добавлено через 5 минут
Вот так вывожу (это в случае с parents)
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php
include ("bd.php");
 
function display_menus($parent = 0)
{
 $query = mysql_query("SELECT * FROM `menu` WHERE `parent` = '$parent' ORDER BY `title`") or die(mysql_error());
 if (mysql_num_rows($query) > 0)
 {
  echo "<ul>";
  while ($row = mysql_fetch_array($query))
  {
   echo "<li> <a href='index.php?menuitem=".$row['id']."&parents=".$row['parent']."&title=".$row['title']."'>" .$row['title']. "</a>";
   display_menus($row['title']);
   echo "</li>";
  }
  echo "</ul>";
 }
}
echo "Семестр";
display_menus();
 
?>
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.04.2014, 13:02
Ответы с готовыми решениями:

Правильная организация связанных таблиц
у меня есть 2 таблицы &quot;новости&quot; и &quot;категория&quot;, которые должны быть связаны. так вот я сначала просто сделал дополнительное поле в таблице...

Правильная организация базы данных
Добрый вечер уважаемый форум. Изучаю php путем создания своей небольшой игры. Сейчас добрался до момента который не могу разобрать. У...

Правильная организация изображений на проекте
Доброго времени суток! Вопрос одновременно касается как php так и mysql поэтому по логике разместил в это разделе надеюсь правильно. ...

25
08.04.2014, 17:49

Не по теме:

ох как-то сложно у вас все... да и не просто... разные parent'ы и прочее... что-то это жесть какая-то... почему так? ... о боги... сейчас нет сил понять все это.... м.б. позднее

0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
08.04.2014, 18:53  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
ох как-то сложно у вас все... да и не просто... разные parent'ы и прочее... что-то это жесть какая-то... почему так? ... о боги... сейчас нет сил понять все это.... м.б. позднее
В том то и дело, что с parent'ами то я сделал. НО, потом с главной таблицей проблемы появляются, поэтому думаю нужно без них делать. А вот как без них, вообще ума не приложу...
0
177 / 125 / 28
Регистрация: 30.10.2013
Сообщений: 686
09.04.2014, 09:28
так... давайте поступать просто и грубовато... начнем с вывода списка семестров. Напишите пожалуйста код, который бы вывел только семестры списком. Предоставьте сюда код и скриншот результата.
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
09.04.2014, 09:59  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
так... давайте поступать просто и грубовато... начнем с вывода списка семестров. Напишите пожалуйста код, который бы вывел только семестры списком. Предоставьте сюда код и скриншот результата.
Ну собственно код:
PHP
1
2
3
4
5
6
echo "Семестры:<br>";
$catalog = mysql_query("SELECT * FROM `catalog` ORDER BY `semestr`");
while($row = mysql_fetch_array($catalog))
{
 echo $row ['semestr']; echo "<br>";
}
А вот результат (не ввиде скриншота, а текстом)
Code
1
2
3
4
5
6
7
8
9
10
Семестры:
3
3
3
7
7
7
8
8
8
Делал через таблицу, которая в первом посту самая верхняя
0
177 / 125 / 28
Регистрация: 30.10.2013
Сообщений: 686
09.04.2014, 10:04
отлично, а теперь давайте сделаем так, чтобы семестры не повторялись, воспользуйтесь такой функцией, как DISTINCT. Пример можно посмотреть тут

и после того, как сделаете - покажите код и скриншот
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
09.04.2014, 20:07  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
и после того, как сделаете - покажите код и скриншот
PHP
1
2
3
4
5
6
echo "Семестры:<br>";
$catalog = mysql_query("SELECT DISTINCT `semestr` FROM `catalog` ORDER BY `semestr`");
while($row = mysql_fetch_array($catalog))
{
 echo $row ['semestr']; echo "<br>";
}
Результат:
Code
1
2
3
4
Семестры:
3
7
8
И да, в запросе получается выбрал только семестры. А как будет правильно выбрать все, но при этом еще и сделать DISTINCT `semestr`? По ссылке прочитал, но не понял.

Добавлено через 9 часов 57 минут
Не уж то ни кто не делал такого?
0
15 / 15 / 9
Регистрация: 22.11.2013
Сообщений: 762
09.04.2014, 20:17
Цитата Сообщение от TheRealKos Посмотреть сообщение
А как будет правильно выбрать все
"SELECT * FROM `catalog`"
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
09.04.2014, 20:21  [ТС]
Цитата Сообщение от bb_oo Посмотреть сообщение
"SELECT * FROM `catalog`"
Я понимаю что так будет выбрано всё... Так и было...
Имел ввиду, что как выбрать все и при этом сделать DISTINCT `semestr`?
0
177 / 125 / 28
Регистрация: 30.10.2013
Сообщений: 686
09.04.2014, 20:21
TheRealKos, тонкостей не знаю, но один простой путь есть.
SQL
1
SELECT DISTINCT `semestr`, `Predmet`, `Group` FROM `catalog` ORDER BY `semestr`
Следующий шаг программы будет позднее )
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
10.04.2014, 21:27  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
Следующий шаг программы будет позднее )
Как там продвижение решения?)
0
177 / 125 / 28
Регистрация: 30.10.2013
Сообщений: 686
11.04.2014, 11:32

Не по теме:

Так, я пожалуй добавлю, что сейчас мы делаем грубое решение, 100% есть более красивое и оптимальное. После того, как доведем до рабочего состояния - вы сможете переделать и оптимизировать как захотите



Теперь выберите для каждого семестра свои предметы. Создайте массив такого вида
PHP
1
$semesters[$numberOfSemester] = array($predmet1, $predmet2);
Как я сказал, нужны только названия предметов
предоставьте var_dump этого массива
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
11.04.2014, 19:13  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
Как я сказал, нужны только названия предметов
предоставьте var_dump этого массива
Не понимаю не много как код записать. Сделал такой код:
PHP
1
2
3
4
5
6
7
8
echo "Семестры:<br>";
$catalog = mysql_query("SELECT DISTINCT `semestr` FROM `catalog` ORDER BY `semestr`");
while($row = mysql_fetch_array($catalog))
{
 echo $row['semestr']; echo "<br>";
 $semesters[$numberOfSemester] = array($predmet1, $predmet2);
 var_dump($semesters[$numberOfSemester]);
}
А вот результат:
Code
1
2
3
4
3
array(2) { [0]=> NULL [1]=> NULL } 7
array(2) { [0]=> NULL [1]=> NULL } 8
array(2) { [0]=> NULL [1]=> NULL }
Явно не правильно написал я...
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
11.04.2014, 23:45
Цитата Сообщение от TheRealKos Посмотреть сообщение
Явно не правильно написал я...
конечно, вы тупо переписали
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
$semesters[$numberOfSemester] = array($predmet1, $predmet2);
а нужно хоть немного думать
PHP
1
2
3
4
5
6
7
8
$catalog = mysql_query("SELECT DISTINCT `semestr`,`predmet` FROM `catalog` ORDER BY `semestr`");
$semesters = array();
while($row = mysql_fetch_assoc($catalog))
{
 echo $row['semestr']; echo "<br>";
 $semesters[$row['semestr']][] = $row['predmet'];
 var_dump($semesters);
}
1
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
11.04.2014, 23:49  [ТС]
Цитата Сообщение от fanatikus Посмотреть сообщение
конечно, вы тупо переписали
Цитата Сообщение от fanatikus Посмотреть сообщение
а нужно хоть немного думать
Я не понял откуда взять $numberOfSemester и $predmet1, $predmet2. Но спасибо Вам.

Вот что вывело:
Code
1
2
3
4
5
6
7
8
9
Семестры:
3
array(1) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } } 
7
array(2) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } [7]=> array(1) { [0]=> string(2) "МО" } } 
8
array(3) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } [7]=> array(1) { [0]=> string(2) "МО" } [8]=> array(1) { [0]=> string(5) "АКиТП" } } 
8
array(3) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } [7]=> array(1) { [0]=> string(2) "МО" } [8]=> array(2) { [0]=> string(5) "АКиТП" [1]=> string(4) "Пр.Л" } }
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
12.04.2014, 18:43
немного протупил, var_dump нужно вынести из цикла, и увидите массив, который получился
Я не понял откуда взять $numberOfSemester и $predmet1, $predmet2.
ненужно их ниоткуда брать. это вам показали пример какой должен быть массив
массив $semesters , ключами которого будут номера семестров, а значениями, массив предметов
я вам показал как сделать такой массив
вот от
PHP
1
array(3) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } [7]=> array(1) { [0]=> string(2) "МО" } [8]=> array(2) { [0]=> string(5) "АКиТП" [1]=> string(4) "Пр.Л" } }
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
12.04.2014, 18:51  [ТС]
Цитата Сообщение от AmsTaFFix Посмотреть сообщение
предоставьте var_dump этого массива
Цитата Сообщение от fanatikus Посмотреть сообщение
var_dump нужно вынести из цикла
Собственно вот тогда код:
PHP
1
2
3
4
5
6
7
8
9
10
11
echo "Семестры:<br>";
$catalog = mysql_query("SELECT DISTINCT `semestr`,`predmet` FROM `catalog` ORDER BY `semestr`");
$semesters = array();
while($row = mysql_fetch_assoc($catalog))
{
 echo $row['semestr']; echo "<br>";
 $semesters[$row['semestr']][] = $row['predmet'];
 
}
 var_dump($semesters);
 echo "<br>";
А вот результат:
Code
1
2
3
4
5
3
7
8
8
array(3) { [3]=> array(1) { [0]=> string(6) "ПнаЯВУ" } [7]=> array(1) { [0]=> string(2) "МО" } [8]=> array(2) { [0]=> string(5) "АКиТП" [1]=> string(4) "Пр.Л" } }
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
12.04.2014, 19:09
Цитата Сообщение от TheRealKos Посмотреть сообщение
А вот результат:
прекрасно, получили массив который требовался
я подсказал, как сформировать необходимый массив (по совету AmsTaFFix) такого вида
PHP
1
$semesters[$numberOfSemester] = array($predmet1, $predmet2);
а что с ним дальше делать, я не вникал
0
2 / 2 / 3
Регистрация: 11.09.2011
Сообщений: 557
12.04.2014, 19:12  [ТС]
Цитата Сообщение от fanatikus Посмотреть сообщение
а что с ним дальше делать, я не вникал
Нужно вывести древовидное меню из базы (если знаете и если не сложно, подскажите). Всё описание есть в первом посте.
0
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
12.04.2014, 20:22
Лучший ответ Сообщение было отмечено TheRealKos как решение

Решение

как-то так
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php 
$catalog = mysql_query("SELECT DISTINCT `semestr`,`predmet`,`group` FROM `catalog` ORDER BY `semestr`");
$semesters = array();
 
while($row = mysql_fetch_assoc($catalog))
{
  $semesters[$row['semestr']][$row['predmet']][] = $row['group'];
} 
 
?>
<ul>
    <?foreach($semesters as $k => $v):?>
        <li><?=$k?></li>
        <ul>
            <?foreach($v as $k1 => $v1):?>
                <li><?=$k1?></li>
                <ul>
                    <?foreach($v1 as $k2 => $v2):?>
                        <li><?=$v2?></li>
                    <?endforeach?>
                </ul>
            <?endforeach?>
        </ul>
    <?endforeach?>
</ul>
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.04.2014, 20:22
Помогаю со студенческими работами здесь

Организация Древовидного списка в ComboBox
всем привет, как огранизовать combobox на примере как на этом форуме, например при создании темы combobox &quot;Префикс:&quot; с...

Реализация древовидного меню в LCD на МК
Здравствуйте, вобщем у меня есть задание написать меню,которое будет выводиться на lcd экран , для atmega16 , я программист си шарп ,...

Кэширование функции загрузки древовидного меню
Добрый день. Как можно за кэшировать функцию которая выводит древовидное меню.

Создание древовидного меню на сайте в django
Здравствуйте. Есть такая задача: Необходимо создать сайт на Python(Django,Flask) или Java (я выбрал Django!), меню будет состоять из...

Подскажите плагин для бокового древовидного меню
Добрый день. Нужен плагин для бокового дублирующего меню категорий товаров, как на этом сайте, например,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru