Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][MYSQL]Aktualizacja wybranego rekordu
zientek18
post
Post #1





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 8.01.2006

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


Witam ponownie, mam nowy problemik mianowicie sprawa przedstawia się następująco chcę wysłać zmienną do bazy danych (aktualizować ją)

Mam błąd tylko nie wiem gdzie. Tabela ma dwa pola id i zaw.
Chcę zrobić update dla pola id = cennik i zmienić pole zaw dla tego id

  1. <?php
  2. if(isset($_POST['kod']))
  3. {
  4.    $tekst = $_POST['kod'];
  5.    
  6.    $dodaj = "UPDATE page(id, zaw)
  7.        VALUES (cennik, '$tekst')";
  8.    $wynik = mysql_query($dodaj) or die(mysql_error());
  9. }
  10. ?>


Pozdr
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 7)
_olo_1984
post
Post #2





Grupa: Zarejestrowani
Postów: 289
Pomógł: 77
Dołączył: 5.08.2006

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


nie wiem czy dobrze rozumiem, ale chyba id raczej powinno być typu int. Pozatym jak robisz update to musisz wskazać, który rekord (chyba że wszystkie), więc zapytanie powinieneś konstruować w stylu:
  1. UPDATE page SET zaw="cos" WHERE id=jakis_id

pozatym nie napisałeś jaki błąd dostajesz ...
pozdr
Go to the top of the page
+Quote Post
zientek18
post
Post #3





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 8.01.2006

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


Cytat(_olo_1984 @ 26.06.2009, 11:32:14 ) *
nie wiem czy dobrze rozumiem, ale chyba id raczej powinno być typu int. Pozatym jak robisz update to musisz wskazać, który rekord (chyba że wszystkie), więc zapytanie powinieneś konstruować w stylu:
  1. UPDATE page SET zaw="cos" WHERE id=jakis_id

pozatym nie napisałeś jaki błąd dostajesz ...
pozdr


Napisałem coś takiego

  1. <?php
  2. if(isset($_POST['kod']))
  3. {
  4.    $tekst = $_POST['kod'];
  5.    
  6.    $dodaj = "UPDATE SET zaw = $tekst WHERE id = cennik";
  7.    $wynik = mysql_query($dodaj) or die(mysql_error());
  8. }
  9. ?>


I wyskakuje błąd You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SET zaw =
Go to the top of the page
+Quote Post
skowron-line
post
Post #4





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

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


  1. <?php
  2. if(isset($_POST['kod']))
  3. {
  4.   $tekst = $_POST['kod'];
  5.  
  6.   $dodaj = 'UPDATE SET zaw ="'. $tekst .'" WHERE id = cennik';
  7.   $wynik = mysql_query($dodaj) or die(mysql_error());
  8. }
  9. ?>


stringi trzeba objąć w " + brak podanej tabeli (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Ten post edytował skowron-line 26.06.2009, 12:46:07
Go to the top of the page
+Quote Post
_olo_1984
post
Post #5





Grupa: Zarejestrowani
Postów: 289
Pomógł: 77
Dołączył: 5.08.2006

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


  1. <?php
  2. $dodaj = 'UPDATE page SET zaw="'.$tekst.'" WHERE id="cennik"';
  3. ?>

żebyś już mógł sobie skopiować :-)
Go to the top of the page
+Quote Post
zientek18
post
Post #6





Grupa: Zarejestrowani
Postów: 45
Pomógł: 0
Dołączył: 8.01.2006

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


Okej działa, sorka za zamieszanie! Dziekuje!

Ten post edytował zientek18 26.06.2009, 12:58:33
Go to the top of the page
+Quote Post
piotrooo89
post
Post #7


Newsman


Grupa: Moderatorzy
Postów: 4 005
Pomógł: 548
Dołączył: 7.04.2008
Skąd: Trzebinia/Kraków




"UPDATE SET zaw = ".'$tekst'." WHERE id = cennik";

!=

'UPDATE page SET zaw="'.$tekst.'" WHERE id="cennik"';

kurcze chłopie nie będziemy po Tobie poprawiać każdej dupereli.
Go to the top of the page
+Quote Post
-lukasamd-
post
Post #8





Goście







Dodajmy jeszcze, że $_POST['kod'] nie ulga żadnemu obrabianiu w celu zabepieczenia, a to niezbyt dobre rozwiązanie.

Warto więc zrobić:

  1. <?php
  2. $tekst = mysql_escape_string($_POST['kod']);
  3. ?>
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: 9.10.2025 - 00:15