Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [php][mysql]Problem z dodawaniem reokdu do bazy z select.
bobo168
post
Post #1





Grupa: Zarejestrowani
Postów: 201
Pomógł: 9
Dołączył: 23.08.2006

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


Witam chce zrobić dodawanie kateogrii do bazy danych za pomocą formularza select i mam:
  1. <?php
  2. $kategoria = $_POST['kategoria'];
  3.  $opis = $_POST['opis'];
  4. $obrazek = $_POST['obrazek'];
  5. $adres = $_POST['adres'];
  6. $nazwa = $_POST['nazwa']; 
  7. $sql = "INSERT INTO filmy SET
  8. opis='$opis',
  9. kategoria='$kategoria',
  10. obrazek='$obrazek',
  11. adres='$adres',
  12. nazwa='$nazwa'";
  13. if (@mysql_query($sql)) {
  14. echo '<p>Dodano nowy osrodek!</p>';
  15. }
  16. ?>

I formularz select i pobieranie danych kategorii:
  1. $cats = @mysql_query('SELECT id, nazwa FROM kategorie');
  2. if (!$cats) {
  3. exit('<p>Nie można pobrać listy kategorii ' .
  4. 'z bazy danych.</p>');
  5. <?php
  6. while ($cat = mysql_fetch_array($cats)) {
  7. $cid = $cat['id'];
  8. $cname = htmlspecialchars($cat['nazwa']);
  9. echo "<label><select name='kategoria' size='1'> " .
  10. "<option value='$cname' />$cname</option></label></select>";
  11. }
  12. ?>

To jest oczywięcie tylo część kodu... NIestety ten kod cos szfankuje bo wypisuje nazwy kategorii w polu select ale ich nie dodaje do bazy ;/ Prosze o pomoc...
Go to the top of the page
+Quote Post
wipo
post
Post #2





Grupa: Zarejestrowani
Postów: 856
Pomógł: 19
Dołączył: 30.08.2005
Skąd: 100lica

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


A dodaj tak:

$sql = "INSERT INTO filmy values(
'$opis',
'$kategoria',
'$obrazek',
'$adres',
'$nazwa')";
Go to the top of the page
+Quote Post
bobo168
post
Post #3





Grupa: Zarejestrowani
Postów: 201
Pomógł: 9
Dołączył: 23.08.2006

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


Nie pomogło
Go to the top of the page
+Quote Post
wipo
post
Post #4





Grupa: Zarejestrowani
Postów: 856
Pomógł: 19
Dołączył: 30.08.2005
Skąd: 100lica

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


N napisz na końcu

print $sql;
print mysql_error();
Go to the top of the page
+Quote Post
skowron-line
post
Post #5





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


  1. <?php
  2. $sql = 'INSERT INTO filmy values(
  3. " '.$opis.' ",
  4. " '.$kategoria.' ",
  5. " '.$obrazek.' ",
  6. " '.$adres.' ",
  7. " '.$nazwa.' ")';
  8. ?>
Go to the top of the page
+Quote Post
bobo168
post
Post #6





Grupa: Zarejestrowani
Postów: 201
Pomógł: 9
Dołączył: 23.08.2006

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


Jak tak zapisze to wyskakuje błąd:
Kod
Column count doesn't match value count at row 1
Go to the top of the page
+Quote Post
wipo
post
Post #7





Grupa: Zarejestrowani
Postów: 856
Pomógł: 19
Dołączył: 30.08.2005
Skąd: 100lica

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


Cytat(bobo168 @ 22.10.2006, 15:02:30 ) *
Jak tak zapisze to wyskakuje błąd:
Kod
Column count doesn't match value count at row 1

A pokaż schemat tabeli
Go to the top of the page
+Quote Post
skowron-line
post
Post #8





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


  1. <?php
  2. $sql = 'INSERT INTO filmy(opis, kategoria, obrazek, adres, nazwa) values(
  3. " '.$opis.' ",
  4. " '.$kategoria.' ",
  5. " '.$obrazek.' ",
  6. " '.$adres.' ",
  7. " '.$nazwa.' ")';
  8. ?>

Kod
Column count doesn't match value count at row 1

to znaczy ze ilosc podanych zmiennych nie odpowiada ilosci kolumn w bazie bo jak wpiszesz samo "filmy" to wychodzi na to ze chcesz wypelnic wszystkie pola a jak w nawiasie wpiszesz nazwe pol to bedzie grac (IMG:http://forum.php.pl/style_emoticons/default/guitar.gif)

Ten post edytował skowron-line 22.10.2006, 20:49:24
Go to the top of the page
+Quote Post
jarrod
post
Post #9





Grupa: Zarejestrowani
Postów: 312
Pomógł: 9
Dołączył: 14.10.2006
Skąd: warszawa

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


jeszcze zwrócę uwagę na "label" (select w formularzu) który zupełnie ci tutaj nic nie daje... Label możesz użyć do pola typu radio. Pozatym podatawowy błąd:
  1. <label><select> ... </label></select>

Jeden z tych tagów nie jest zamknięty i się nie zaczyna.
kurshtml.boo.pl
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:27