Salam.
Məm treevievv deyilən bir forma qurmaq istiyirəm php və mysql ilə. bu əsasən drop-dovvn menyularda istifadə olunur ama mənə kateqoriya yaratmaq üçün lazımdır. sadə cədvələ id, name və parent id atributları var.
———————-
id|name|parentId|
———————-
1|Rock|NULL|
2|Alternative Rock|1
3|Metal|1
4|Classic|1
5|70s|4
6|90s|4
7|Jazz|NULL
8|Folk-Jazz|7
9|Opera-Jazz|7
bu tipli bir cədvəldəki yazıları php vasitəsi ilə kateqoriya şəklində əks etdirmək istiyirəm nested listlər vasitəsi ilə.
Məslən yuxaridakı cədvəl
-Rock
-Alternative
-Metal
-Classic
-70s
-90s
-Jazz
-Folk-Jazz
-Opera-Jazz
bunu necə etməyi məsləhət görərdiniz.bir növ forumlarda istifadə olunan düzülüşə bənziyir. SQLdə JOİNlər vasitəsi ilə etməyi bilirəm. ama mənə işin çox hissəsini php-nin görməyi lazımdır. sadə bir funksiya daxilində nested vvhile loop-u ilə, adi dəyişənlərlə.
bir neçə query-dən istifadə edərək də istədiyim nəticəni ala bilirəm. ama fikrimcə daha asan yolu olmalıdır. İstənilən yönləndirmə və köməyinizin faydası olar.Əvvəlcədn təşəkkür edirəm.
Verilmiş cavablar və yazılan şərhlər (7 cavab var)
2
Salam. Mən bu haqda bloqumda yazmışdım. İndi bloqa girmək mümkün olmasa da Google keşdə qalanları oxuya bilərsiniz.
http://pastebin.com/pPxLRgx7
0
çox sagolun. ama məncə istədiyim nəticəni vermir sizin postdaki skript. çünki siz parent olaraq parentİd-si sıfır olanları seçirsiniz. məndə isə parent id sıfırdan fərqli də ola bilir. yəni child kateqoriya həm də parent kateqoriya ola bilir. Classic həm child kateqoriyadır həm də 70s və 90s üçün parent kateqoriyadır. sizin skript 1ci dərəcəyə qədər enə bilir. Yəni menyu var alt menyu var məndə isə alt menyunun da altmenyusu var.
0
array(massiv)-dən istifadə edib istədiyim nəticəni ala bilirəm əslində.eləcədə SQL-də JOİN-lər vastəsi ilə istədiyimi ala bilirə,php-dən minimum istifadə edib. massivdən istifadə etmədən nəticəni almaq istiyirəm. bu da deyəsən mümkün deyil. zəhmət olmasa bu yöndə məsləhət verin. sizcə arraysiz mümkündür kateqoriya qurmaq? normal dəyişəndən istifadə edib bir nəticə almaq olar?özüm də araşdırıram tapsam yazacam.çox sağolun.
0
Bahruz, onda sizə məsləhət görərdim ki, WordPress Core-sində yerləşən wp_list_categories-in strukturunu araşdırasınız. O eynən siz deyən işi görür(məhdudiyyətsiz sayda alt pilləsi olan tree), hər halda wordpress-i quranlar əminəm ki ən optimal yoldan istifadə ediblər. Əgər tapacağınız o yol sizin üçün yeni olmayacaqsa, deməli hazırda bildiyiniz üsullar ən optimal variantdır.
Salam, bu məsələni aşağıdakı rekursiya ilə həll etmək mümkündür:
* Qeyd edim ki, bu sadəcə bir nümunədir yaxşı olarki bu rekursiyanı DB serverde yazasınız və applicationdan həmin stored procedure -ni çağırasız.
0
Kiməsə gələcəkdə lazım ola bilər, həlli yerləşdirirəm.
1ci üsul array (massiv)-dən istifadə etməklə, fikrimcə bu ən ugurlu seçimdir, sonsuz sayda və sonsuz dərinlikdə parent-child (kateqoriya-altkateqoriya) münasibəti yaratmaq olar.
0
2ci üsul ne funksiyadan istifadə olunur nə də arraydən. birinicidən uzundu və kodun uzunluğu dərinliyə görə daha da uzanır.əlverişsiz olsa da kiməsə lazım ola bilər. məsələn mənə bu üsulla yazmaq lazım idi. aşağıdakı nümunədə 3cü dərəcəyə qədər dəriliyə gedir kod. yəni ana kateqoriya 1-dir, uşağı 2dir, 3isə 2nin usagıdır.
Simple Database Access
Bulletin Board
<?php
$i=0;
while ($i
<?php
$j=0;
echo "”;
echo “”;
echo ““.$subject.’ – ‘;
echo ““;
echo ““.$author.”“;
echo ‘ ‘.$date;
echo “”;
while ($j
<?php
$k=0;
echo "”;
echo “”;
echo ““.$child_subject.’ – ‘;
echo ““;
echo ““.$child_author.”“;
echo ‘ ‘.$child_date;
echo “”;
while ($k
<?php
echo "”;
echo “”;
echo ““.$grandchild_subject.’ – ‘;
echo ““;
echo ““.$grandchild_author.”“;
echo ‘ ‘.$grandchild_date;
echo “”;
echo “”;
$k++;}
echo “”;
$j++;}
echo “”;
$i++;
}
mysql_close();
?>
[/code/
Sual verin
Cavab verin