Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Problem z klasą, Dodawanie danych poprzez PDO
MMySlime
post
Post #1





Grupa: Zarejestrowani
Postów: 45
Pomógł: 1
Dołączył: 22.08.2012

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


Witam,

stworzyłem sobie klasę łączącą z bazą danych, a w niej funkcję insert, która nie działa poprawnie. Nie ma żadnych błędów ale przeglądając bazę danych nie widać nowo dodanych wartości.

Funkcja:
  1. public function insert( $table, $values){
  2.  
  3. // Set Up Columns
  4.  
  5. $key = array_keys($values);
  6. $column = implode(',',$key);
  7. $column = '(' . $column . ')';
  8.  
  9. // Set Up Rows
  10.  
  11. $row = implode(',',$values);
  12. $row = '(' . $row . ')';
  13.  
  14. // INSERT INTO table_name (column1, column2, column3,...) VALUES (value1, value2, value3,...)
  15.  
  16. $insert = $this->db->prepare('INSERT INTO :table :column VALUES :row');
  17.  
  18. $insert->bindParam(':table', $table);
  19. $insert->bindParam(':column', $column);
  20. $insert->bindParam(':row', $row);
  21.  
  22. $insert->execute();
  23.  
  24. }


Dziękuję za wszelkie odpowiedzi (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
MMySlime
post
Post #2





Grupa: Zarejestrowani
Postów: 45
Pomógł: 1
Dołączył: 22.08.2012

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


Ehhh, szkoda że nie da się tego zautomatyzować.
W każdym bądź razie dzięki za pomoc!
Go to the top of the page
+Quote Post
zegarek84
post
Post #3





Grupa: Zarejestrowani
Postów: 1 332
Pomógł: 294
Dołączył: 12.10.2008
Skąd: Olkusz

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


Cytat(MMySlime @ 11.11.2012, 16:47:14 ) *
Ehhh, szkoda że nie da się tego zautomatyzować.

nie jestem żadnym programistą a już to robiłem kilka razy ;p - da się to rozsądnie zautomatyzować nie narażając się na sql iniection ale trochę pomyśl...

możesz wartości zimplodować tyle razy ile ich masz np. po znaku zapytania, poczytaj w manualu jak wtedy bindować i wtedy przypisz tablicę (zwróć uwagę od którego indeksu binduje - łatwiej Ci będzie to zrobić w pętli ;p), lub gdy tworzysz dynamiczne zapytanie to do kluczy musisz dać przedrostek ":" i potem nawet w skrócie do execute dać całą tablicę lub zbindować w pętli po kluczu... nie jestem za dawaniem gotowców niestety więc tylko nakierowuję, jednak znowu się powtórzę, że musisz zrobić dynamiczne zapytanie SQL z parametrami a potem to zbindować, ale jeszcze poczytaj o różnicy w bindowaniu przez referencję a przez wartość ;p - są do tego 2 funkcje ;p lub tablicę możesz przekazać jeszcze raz piszę w execute jeśli nie stosujesz dodatkowych parametrów przy bindowaniu...
Go to the top of the page
+Quote Post

Posty w temacie


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: 29.12.2025 - 07:09