![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 518 Pomógł: 18 Dołączył: 21.07.2008 Ostrzeżenie: (0%) ![]() ![]() |
witam.
Zaczynam przepisywanie pewnego programiku na PDO i niestety miao być łatwiej a jest trudniej. Problem dotyczy dynamicznego tworzenia zapytania. Chciałbym aby pytanie stworzone zostało na podstawie tablicy i iteracji po niej.
Jesli wiem jakie wartosci chce wrzucic do zapytania to wszystko da sie zrobic. Co jesli nie wiem ile danych bedzie w zapytaniu i musze to stworzyc dynamicznie ? za pomoc z gory dziekuje i pozdrawiam G |
|
|
![]() |
![]()
Post
#2
|
|
![]() Grupa: Moderatorzy Postów: 36 557 Pomógł: 6315 Dołączył: 27.12.2004 ![]() |
Najpierw robisz PREPARE na $sql, a dopiero potem w petli to $sql dynamicznie tworzysz.... naprawde nie widzisz to ewidetnego bledu LOGICZNEGO?
-------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
![]()
Post
#3
|
|
![]() Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
1. Skorzystaj z WHERE id IN(...) zamiast bezsensownej serii OR-ów.
2. Niestety PDO nie pozwala na podpięcie całej tablicy, będziesz musiał najpierw przygotować zapytanie w stylu ...WHERE id IN(?, ?, ?, ?, ..., ?, ?, ?, ?). 3. Możesz skorzystać z Doctrine'owskego DBAL-a, który rozwiązuje pow. problem oraz udostępnia trochę przyjemnych dodatków. |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 518 Pomógł: 18 Dołączył: 21.07.2008 Ostrzeżenie: (0%) ![]() ![]() |
nospor: nie no wiem ze to co napisalem jest zle i nie ma sensu. chodzilo mi tylko i wylacznie o zobrazowanie problemu ktory chce rozwiazac.
Tak jak wspomnialem przepisuje programik na PDO i staram sie przepisac to co w tej chwili dziala na nowy system. Crozin: wlasnie szukalem takiej podpowiedzi. Dla innych poszukujacych rozwiazania tego problemu podaje rozwiazanie:
pozdrawiam G |
|
|
![]()
Post
#5
|
|
![]() Grupa: Moderatorzy Postów: 36 557 Pomógł: 6315 Dołączył: 27.12.2004 ![]() |
Cytat nospor: nie no wiem ze to co napisalem jest zle i nie ma sensu. chodzilo mi tylko i wylacznie o zobrazowanie problemu ktory chce rozwiazac. No ale w moim poscie padla przeciez odpowiedz co robisz zle i posrednio jak to nalezy poprawic.crozin napisal to samo co ja, tylko dorzucil, ze zamiast OR masz uzyc IN, ale tak czy siak wpierw masz zbudowac cale zapytanie a dopiero potem PREPARE. Tak czy siak problem rozwiazany. -------------------- "Myśl, myśl, myśl..." - Kubuś Puchatek || "Manual, manual, manual..." - Kubuś Programista "Szukaj, szukaj, szukaj..." - Kubuś Odkrywca || "Debuguj, debuguj, debuguj..." - Kubuś Developer |
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 518 Pomógł: 18 Dołączył: 21.07.2008 Ostrzeżenie: (0%) ![]() ![]() |
dziekuje
|
|
|
![]() ![]() |
![]() |
Wersja Lo-Fi | Aktualny czas: 14.08.2025 - 04:28 |