Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP][MySQL]PDO Insert into select
@rtur
post
Post #1





Grupa: Zarejestrowani
Postów: 254
Pomógł: 3
Dołączył: 23.02.2006

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


Witam w jaki sposób z PDO dodać rekord do tabeli pobierając jedną z wartości z innej tabeli?
próbowałem czymś takim, ale nie chce działać...
  1. $stmt = $pdo -> prepare(INSERT INTO tabela1 (id,name) (SELECT sid,:nazwa FROM tabela2 WHERE nazwa=:nazwa));
  2. $stmt -> bindValue(':nazwa', $nazwa, PDO::PARAM_STR);
  3. $stmt -> execute();
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 4)
trueblue
post
Post #2





Grupa: Zarejestrowani
Postów: 6 806
Pomógł: 1828
Dołączył: 11.03.2014

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


Musisz podpiąć parametry jako dwa niezależnie pomimo tej samej wartości.
Np. :nazwa1 i :nazwa2

EDIT: No, i zapytanie ma być stringiem, więc albo ' albo ".

Ten post edytował trueblue 25.04.2015, 08:50:48
Go to the top of the page
+Quote Post
@rtur
post
Post #3





Grupa: Zarejestrowani
Postów: 254
Pomógł: 3
Dołączył: 23.02.2006

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


Dzięki...
  1. $stmt = $pdo -> prepare('INSERT INTO tabela1 (id,name) (SELECT id, :nazwa FROM tabela2 WHERE tytul=:tytul)');
  2. $stmt -> bindValue(':nazwa', $nazwa, PDO::PARAM_STR);
  3. $stmt -> bindValue(':tytul', $tytul, PDO::PARAM_STR);
  4. $stmt -> execute();


nie bardzo chce działać...

Ten post edytował @rtur 25.04.2015, 09:30:34
Go to the top of the page
+Quote Post
trueblue
post
Post #4





Grupa: Zarejestrowani
Postów: 6 806
Pomógł: 1828
Dołączył: 11.03.2014

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


Zmienna $tytul ma wartość?
Go to the top of the page
+Quote Post
@rtur
post
Post #5





Grupa: Zarejestrowani
Postów: 254
Pomógł: 3
Dołączył: 23.02.2006

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


Dzięki, już działa brakowało jednego apostrofa w kodzie dalej...
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: 23.08.2025 - 07:08