Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][MySQL] Dopisywanie danych
youngen
post 5.07.2012, 08:55:39
Post #1





Grupa: Zarejestrowani
Postów: 18
Pomógł: 0
Dołączył: 5.07.2012

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


Od razu mówię, że jestem nowy w programowaniu. Dopiero niedawno zacząłem. Chcę zrobić tak, aby dopisywało mi dane do mysql.
  1. <?php
  2.  
  3. $produkt1 = $_POST['produkt1'];
  4. $produkt2 = $_POST['produkt2'];
  5. if(!empty($_POST)){
  6. $error = array();
  7. $errors = 0;
  8.  
  9. if(empty($_POST['produkt1'])){
  10. $error[7] = "Nie podano produktu1";
  11. $errors++;
  12. } else {
  13. $_POST['produkt1'] = tekst($_POST['produkt1']);
  14. if(strlen($_POST['produkt1']) < 3 || strlen($_POST['produkt1']) > 100){
  15. $error[3] = "Nieprawidłowa dlugoœć pola produkt1";
  16. $errors++;
  17. }
  18. }
  19.  
  20.  
  21.  
  22. if(empty($_POST['produkt2'])){
  23. $error[3] = "Nie podano produktu2";
  24. $errors++;
  25. } else {
  26. $_POST['produkt2'] = tekst($_POST['produkt2']);
  27. if(strlen($_POST['produkt2']) < 5 || strlen($_POST['produkt2']) > 50){
  28. $error[3] = "Nieprawidłowa długoœć pola produkt2";
  29. $errors++;
  30. }
  31. }
  32.  
  33.  
  34.  
  35.  
  36. {
  37. mysql_query("insert into produkty(produkt1, produkt2) value ('".$_POST['produkt1']."','".$_POST['produkt2']."','");
  38. $error[6] = "Produkt1 i produkt2 zostały dodane";
  39.  
  40. }
  41.  
  42.  
  43. }
  44. ?>


Wszystko niby jest ok, ale do bazy nie dodaje. Nie podałem kodu do formularzy i przycisków, bo tamto mam raczej dobrze smile.gif

Proszę o pomoc, z góry dziękuję
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 9)
emkej
post 5.07.2012, 09:13:27
Post #2





Grupa: Zarejestrowani
Postów: 48
Pomógł: 5
Dołączył: 18.06.2012

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


Nie masz wyswietlania błedów w zapytaniach, więc niby wszystko jest ok, a pewnie MySQL rzuca błedem, zmień:
  1. mysql_query("insert into produkty(produkt1, produkt2) value ('".$_POST['produkt1']."','".$_POST['produkt2']."','");

Na:
  1. mysql_query("insert into produkty(produkt1, produkt2) value ('".$_POST['produkt1']."','".$_POST['produkt2']."','")or die(mysql_error());


... i sprawdz jaki masz błąd :-)

btw. Na pierwszy rzut oka, to w tym zapytaniu jest błąd :-)

Ten post edytował emkej 5.07.2012, 09:14:15


--------------------
http://tropmy.net - narzędzie do badania usability stron WWW.
Go to the top of the page
+Quote Post
!*!
post 5.07.2012, 09:20:09
Post #3





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


- po co przypisujesz POST do zmiennych?
- sprawdzaj czy formularz został wysłany, przez isset() a nie !empty i nie odwołuj się do całej tablicy POST, a tylko do formularza, żeby to sprawdzić.
- tak samo przy sprawdzaniu czy pola formularza zostają przesłane
- zainteresuj się PDO, zamiast mysql_*
- czy występują jakieś błędy?
- jeśli nie, a rekord nie zostaje dodany, to albo zapytanie jest błędne/puste patrząc na Twój kod, to pierwsze.

http://pl.wikibooks.org/wiki/PHP/Jak_to_się_robiło_kiedyś%3F

  1. mysql_query("insert into produkty(produkt1, produkt2) value ('".$_POST['produkt1']."','".$_POST['produkt2']."','");
  2. //czyli, patrz link wyżej.
  3. mysql_query('INSERT INTO `produkty` (`produkt1`, `produkt2`) VALUES(`produkt1`, `produkt2`)


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
youngen
post 5.07.2012, 09:31:17
Post #4





Grupa: Zarejestrowani
Postów: 18
Pomógł: 0
Dołączył: 5.07.2012

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


Właśnie występuję 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 '' at line 1

Ja dopiero zaczynam z mysql i php.

"Jeśli nie, a rekord nie zostaje dodany, to albo zapytanie jest błędne/puste patrząc na Twój kod, to pierwsze."

Możesz powiedzieć gdzie dokładnie jest ten błąd? W pierwszej linijce kodu mam: <?php, nie wiem gdzie tam mogłem błąd zrobić ;p
Go to the top of the page
+Quote Post
!*!
post 5.07.2012, 09:37:03
Post #5





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


W Twoim zapytaniu jest błąd. Popatrz na kod jaki podałem. I po co podajesz "," na końcu?


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
youngen
post 5.07.2012, 09:41:47
Post #6





Grupa: Zarejestrowani
Postów: 18
Pomógł: 0
Dołączył: 5.07.2012

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


Tylko problem jest taki, że po skopiowaniu tego co podałeś również mam błąd sad.gif
Go to the top of the page
+Quote Post
!*!
post 5.07.2012, 09:57:05
Post #7





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


Bo to przykład kopiuj wklej, w dodatku zły, brakuje ';'. Przeczytałeś powyższy link o tym jak dodawać rekordy do bazy danych? Jaki błąd?


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
youngen
post 5.07.2012, 11:01:10
Post #8





Grupa: Zarejestrowani
Postów: 18
Pomógł: 0
Dołączył: 5.07.2012

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


Ciągle 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 '"INSERT INTO `produkty` (`produkt1`, `produkt2`)"' at line 1

Robiłem już wieloma sposobami, żeby to dodawało i nic :/ Czytałem też to twoje, również mi nie działa.
Go to the top of the page
+Quote Post
!*!
post 5.07.2012, 11:05:55
Post #9





Grupa: Zarejestrowani
Postów: 4 298
Pomógł: 447
Dołączył: 16.11.2006

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


Pokaż cały kod. albo zamiast POST wpisz dane na sztywno. I czy masz dobrze zbudowaną baze danych.


--------------------
Nie udzielam pomocy poprzez PW i nie mam GG.
Niektóre języki programowania, na przykład C# są znane z niezwykłej przenośności (kompatybilność ze wszystkimi wersjami Visty jest wiele warta).
Go to the top of the page
+Quote Post
youngen
post 5.07.2012, 12:17:09
Post #10





Grupa: Zarejestrowani
Postów: 18
Pomógł: 0
Dołączył: 5.07.2012

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


Dobra poradziłem sobie jakoś. Dodałem kilka produktów i pięknie gra gitara smile.gif Trochę to dziwne, że przy 2 produktach za nic nie chciało działać, dodałem teraz 3 i działa biggrin.gif
Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 22.07.2025 - 13:45