Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Problem z formularzem z gotowymi danymi
Forum PHP.pl > Forum > PHP
atchor
Witam serdecznie.

Otóż mam 2 problemy dotyczące formularza w który mają wejsc dane z bazy.

1) Niektore pola się zapełniają właściwie, inne w ogóle. Mam na przykład dwa pola "TEXTAREA" w ktore wbijam dane z pól MySQL "TEXT". Teraz pytanie: dlaczego w jednym z pól TEXTAREA nie pojawia sie tekst?

"input name" == pole w tabeli SQL wiec wykluczam pomyłkę w nazwach pól. Dodam, iż treść pola posiada polskie znaki diakrytyczne gdzie w tabeli MySQL zapisane są przy formacie utf8_general_ci

2) Jak wybrać przy wczytaniu się strony wartość pola SELECT, ktora nalezy do rekordu? Np. dla 7 pracownikow chcialbym wybrac kategorie "Palacz" z listy dostepnych mozliwosci.
Wave
1) Pokaż kod
2) W jaki sposób są te kategorie zapisane?
atchor
Pola w tabeli MySQL są tak samo nazwane jak tutaj
  1. <?php
  2. if(!empty($id))
  3. {
  4. $coding = @mysql_query("SET NAMES latin2") or die(mysql_error());
  5. $ask_for_article = @mysql_query("SELECT * FROM acms_articles WHERE id='$id'") or die(mysql_error());
  6. while($articlerow = @mysql_fetch_array($ask_for_article))
  7. {
  8. echo "<html><head><title>" . $lang['article_to_edit'] . ": " . $articlerow['title'] . "</title></head><body>";
  9. echo "<form action='admin_article_edit.php' method='post'>";
  10. echo "<table class='form'>";
  11. echo "<tr>";
  12. echo "<td><font class='formhead'>Tytu&sup3;</font></td>";
  13. echo "<td><input name='title' maxlenght='150' size='70' value='" . $articlerow['title'] . "'></td>";
  14. echo "</tr>";
  15. echo "<tr>";
  16. echo "<td><font class='formhead'>Wst&ecirc;p do artyku&sup3;u</font></td>";
  17. echo "<td><textarea name='preface' rows='12' cols='50' value=" . $articlerow['preface'] . "></textarea></td>";
  18. echo "</tr>";
  19. if(!empty($articlerow['maintext']))
  20. {
  21. echo "<tr>";
  22. echo "<td><font class='formhead'>Tre&para;&aelig; artyku&sup3;u</font></td>";
  23. echo "<td><textarea name='article' rows='25' cols='50' value=" . $articlerow['maintext'] . "></textarea></td>";
  24. echo "</tr>";
  25. }
  26. else
  27. {
  28. echo "<tr>";
  29. echo "<td><font class='formhead'>Tre&para;&aelig; artyku&sup3;u</font></td>";
  30. echo "<td></td>";
  31. echo "</tr>";
  32. }
  33. ?>
Wave
<textarea> nie ma atrybutu value. Kod dajesz między znaczniki <textarea> i </textarea>.

Co do drugiego pytania to nadal nie wiem o co chodzi.
atchor
dzieki, zapomnialem o tym specyfiku textarea tongue.gif lol

a co do drugiego to chodzi mi o to, by przy wczytaniu pozycji pola wyboru SELECT od razu wybierany był ten, ktory odpowiada konkretnemu rekordowi z bazy. Wedle powyzszego kodu ma to byc kategoria artykułu znajdujaca sie w osobnej tabeli ale w tabeli z artykulem oznaczona jako catid. Pobieram odpowiednim kodem liste kategorii do pola SELECT ale nie wiem jak dla indeksu $articlerow['catid'] wybrac z pola SELECT kategorie przypisana do tego rekordu.

  1. <?php
  2. echo "<tr>";
  3. /* Categories and subcategories display */
  4. $coding = @mysql_query("SET NAMES latin2") or die(mysql_error());
  5. $ask_for_cats = @mysql_query('SELECT id, name FROM acms_cats');
  6. if (!$ask_for_cats)
  7. {
  8. die('<p class="error">Error performing query: ' . mysql_error() . '</p>');
  9. }
  10. $cats = "";
  11. while ($catrow = mysql_fetch_array($ask_for_cats))
  12. {
  13. $cats .= "<option value='{$catrow['id']}'>{$catrow['name']}</option>";
  14. }
  15. echo "<td><font class='formhead'>Kategoria</font></td>";
  16. echo "<td><select name='category'>$cats</select></td>";
  17. echo "</tr>";
  18. ?>
Cienki1980
Jeżeli wartość dla artykułu będzie równa pobranej z bazy podczas wyciągania wszystkich dodaj selected do tworzonego <option>
atchor
no wlasnie w tym problem ze pole ID z tabeli kategorii nie rowna sie polu ID z tabeli artkylow totez chodzi o to, by wybraz z pola SELECTED kategorie ktora ma taki ID jak pole CATID w tabeli artykulow
Wave
  1. SELECT acms_cats.id, acms_cats.name
  2. FROM acms_cats, acms_articles
  3. WHERE acms_articles.id = "[ID]" AND acms_articles.catid = acms_cats.id
  4. LIMIT 1

coś takiego?
atchor
LOL, prosilem o kod wybierajacy pozycje z listy SELECT a nie zapytanie MySQL
Cienki1980
Cytat(atchor @ 11.02.2007, 14:40:09 ) *
no wlasnie w tym problem ze pole ID z tabeli kategorii nie rowna sie polu ID z tabeli artkylow totez chodzi o to, by wybraz z pola SELECTED kategorie ktora ma taki ID jak pole CATID w tabeli artykulow

No to wybierając dane o artykułach wyciągaj też wartość CATID i tą wartość porównuj z ID wyciągnietą z bazy podczas tworzenia SELECT'a
Wave
Cytat(atchor @ 11.02.2007, 15:00:06 ) *
LOL, prosilem o kod wybierajacy pozycje z listy SELECT a nie zapytanie MySQL

A skąd weźmiesz CATID ? z palca ?
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.