Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> wyświetlanie danych z sql i w wierszach i w kolumnach
dragon7
post
Post #1





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 1.10.2010

Ostrzeżenie: (0%)
-----


Chodzi o to, że chcę by na mojej stronie galeria wyświetlana była w sposób po 4 galerie w jednej linii, a następnie przejście do nowej itd., aż do wyświetlenia wszystkich rekordów. Nie wiem jak mam to napisać, czy skorzystać z pętli for czy z funkcji if, no po prostu nie mam pojęcia. Głowię się nad tym już sporo i nic nie mogę wymyślić. Nawet nie wiem jak mam to nazwać szukając w googlach, dlatego postanowiłem napisać na forum i czekać na wasze odpowiedzi

Ten post edytował dragon7 1.10.2010, 16:53:34
Go to the top of the page
+Quote Post
marcio
post
Post #2





Grupa: Zarejestrowani
Postów: 2 291
Pomógł: 156
Dołączył: 23.09.2007
Skąd: ITALY-MILAN

Ostrzeżenie: (10%)
X----


Petla for i reszta z dzielenia, dziel przez 4 jesli masz reszte dodaj <tr>
Go to the top of the page
+Quote Post
CuteOne
post
Post #3





Grupa: Zarejestrowani
Postów: 2 958
Pomógł: 574
Dołączył: 23.09.2008
Skąd: wiesz, że tu jestem?

Ostrzeżenie: (0%)
-----


dla jasności:

  1.  
  2. echo '<table><tr>';
  3.  
  4. for($i=0;$i<count($row_mysql);$i++) {
  5.  
  6. echo '<td>ddwd</td>';
  7.  
  8. if($i%4 == 1) { //juz nie pamiętam czy trzeba wstawić 1 czy 3 ^-^
  9.  
  10. echo '</tr><tr>';
  11. }
  12. }
  13. echo '</tr></table>'


Ten post edytował CuteOne 1.10.2010, 17:10:54
Go to the top of the page
+Quote Post
dragon7
post
Post #4





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 1.10.2010

Ostrzeżenie: (0%)
-----


średnio działa, prawie wszystko ok jak jest 5 galerii to wyświetla po 4 te same, jak mniej to wszystko w jednej linii i to po 3, 2 razy te same a powyżej 5 galerii to w ogóle już hardcor totalny, w zależności od ilości 6 i więcej, zawsze chyba mniej o 1 niż ilość galerii, jak rozwiązać ten problem?? Cały skrypt wygląda tak:
  1. <?php
  2. $conn = mysql_connect("127.0.0.1","root","krasnal");
  3. mysql_select_db("liceum");
  4. $zapytanie = "SELECT * FROM galeria ORDER BY id DESC LIMIT 5;" ;
  5. $wynik = mysql_query($zapytanie);
  6. echo "<table border='0' cellspacing='0' cellpadding='2'><tr>";
  7. while($wpis = mysql_fetch_assoc($wynik)) {
  8. $id=$wpis['id'];
  9. $nazwa=$wpis['nazwa'];
  10. $zdjecie=$wpis['zdjecie'];
  11. $photo = mysql_num_rows($wynik);
  12. for($i=1;$i<$photo;$i++) {
  13. echo "<td width='140' align='left'><b><a href='gal.php?id=$id'>".$nazwa."</a></b><br /><a href='gal.php?id=$id'><img src=".$zdjecie." /></a></td>";
  14. if($i%4 == 0) {
  15. echo '</tr><tr>';
  16. }}}
  17. echo "</tr></table>";
  18. mysql_close($conn);
  19. ?>



Ten post edytował dragon7 2.10.2010, 16:13:43
Go to the top of the page
+Quote Post
andycole
post
Post #5





Grupa: Zarejestrowani
Postów: 71
Pomógł: 1
Dołączył: 14.12.2004

Ostrzeżenie: (0%)
-----


  1. <?php
  2. $conn = mysql_connect("127.0.0.1","root","krasnal");
  3. mysql_select_db("liceum");
  4. $zapytanie = "SELECT * FROM galeria ORDER BY id DESC" ;
  5. $wynik = mysql_query($zapytanie);
  6. echo "<table border='0' cellspacing='0' cellpadding='2'><tr>";
  7. $licznik = 0;
  8. while($wpis = mysql_fetch_assoc($wynik)){
  9. $licznik++;
  10. $id=$wpis['id'];
  11. $nazwa=$wpis['nazwa'];
  12. $zdjecie=$wpis['zdjecie'];
  13. echo "<td width='140' align='left'><b><a href='gal.php?id=$id'>".$nazwa."</a></b><br /><a href='gal.php?id=$id'><img src=".$zdjecie." /></a></td>";
  14. if($licznik%4 == 0) {
  15. echo '</tr><tr>';
  16. }
  17. }
  18. echo "</tr></table>";
  19. mysql_close($conn);
  20. ?>
Go to the top of the page
+Quote Post
dragon7
post
Post #6





Grupa: Zarejestrowani
Postów: 51
Pomógł: 0
Dołączył: 1.10.2010

Ostrzeżenie: (0%)
-----


dzięki wielkie, działa tak jak trzeba:D a limit musiałem zostawić, to będzie strona szkolna, więc w pewnym momencie będzie tyle galerii, że się nie będą mieścić(IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
PiterosWeb
post
Post #7





Grupa: Zarejestrowani
Postów: 48
Pomógł: 2
Dołączył: 2.10.2010
Skąd: Piotrków Trybunalski

Ostrzeżenie: (0%)
-----


A nie było by łatwiej to zrobić na divach (IMG:style_emoticons/default/questionmark.gif)
Robiłem coś takiego i mi to działa fajnie i nie musiałem martwić się o kolejną linię bo gdy mi się nie mieściło to przerzucało mi mi danego diva niżej.
Wystarczyło ustwić odpowiednio diva nadać mu odpowiednie atrybuty i wrzucić to w pętlę np. while i wszystko świetnie gra ;D
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 22.08.2025 - 22:37