![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
![]() Grupa: Zarejestrowani Postów: 218 Pomógł: 0 Dołączył: 14.04.2004 Skąd: Słupsk, Nowy Sącz Ostrzeżenie: (0%) ![]() ![]() |
witam
Jak się odwolac do argumentu z procedury wewnatrz zapytania (chodzi mi o znacznik) przyklad: WHERE `xxx`=`yyy` (porowna wartosc z kolumna yyy) WHERE `xxx`='yyy' (porowna wartosc z wartoscia yyy) WHERE `xxx`=@yyy (porowna wartosc ze zmienna yyy spoza procedury) a co jak mam argument procedury nazwany yyy? kiedy odwolam sie do niego po prostu jako do yyy to wywala error... wiec jak sie do niego odwolac? obchodze to teraz tak, ze przed wywolaniem procedury deklaruje zmienne i przypisuje im wartosci zamiast tworzyc argumenty i potem odwoluje sie przez @, ale to chyba nie jest tak jak manual przykazuje... a w samym manualu nie ma takiego przykladu... jest tylko jak wykonywac operacje na takich argumentach (ale nie widze przykladu z wykorzystaniem tych argumentow w zapytaniu do bazy) jak ktos ma pojecie jak to zrobic, bylbym wdzieczny ![]() k. |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 1 421 Pomógł: 310 Dołączył: 18.04.2012 Ostrzeżenie: (0%) ![]() ![]() |
Trzeba argument przekazać. SQL to nie PHP. Widzi tylko to co ma.
|
|
|
![]()
Post
#3
|
|
![]() Grupa: Zarejestrowani Postów: 218 Pomógł: 0 Dołączył: 14.04.2004 Skąd: Słupsk, Nowy Sącz Ostrzeżenie: (0%) ![]() ![]() |
Trzeba argument przekazać. SQL to nie PHP. Widzi tylko to co ma. Może nie wyraziłem się dość jasno. Argument przekazać umiem, umiem nawet na nim wykonywać operacje (poza zapytaniem), ale nie wiem jak się do niego odwołać z zapytania (ktore jest w procedurze, bo zapytania poza procedurami w ogole nie maja argumentow ![]() Najlepszy byłby przykład np. procedura, ktora zwroci mi sume wartosci z kolumny podanej jako argument w procedurze dla uproszczenie nazwe argument po prostu argument jesli wpisze: SELECT SUM(`argument`) to bedzie szukal kolumny o nazwie 'argument', a takiej nie ma jesli wpisze: SELECT SUM('argument') to bedzie probowal zsumowac stringa jesli wpisze: SELECT SUM(@argument) to bedzie sumowaj zmienna a co mam wpisac by mi zsumowalo kolumne o nazwie przekazanej jako argument do procedury w ktorej jest to zapytanie pozdrawiam, k. |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 282 Pomógł: 89 Dołączył: 12.04.2011 Ostrzeżenie: (0%) ![]() ![]() |
Nie da się argumentu przekazać bezpośrednio do zapytania jako nazwy kolumny, tabeli itp. Tam mogą być tylko identyfikatory. Argumenty bezpośrednio do zapytania można wpisać tylko tam, gdzie normalnie byś wpisywał gotowe wartości. Sam fakt, że czegoś takiego potrzebujesz daje do myślenia nad strukturą bazy. Jeśli jednak koniecznie chcesz to zrobić to musisz pomóc sobie klejonym preparowanym zapytaniem:
|
|
|
![]()
Post
#5
|
|
![]() Grupa: Zarejestrowani Postów: 218 Pomógł: 0 Dołączył: 14.04.2004 Skąd: Słupsk, Nowy Sącz Ostrzeżenie: (0%) ![]() ![]() |
Nie da się argumentu przekazać bezpośrednio do zapytania jako nazwy kolumny, tabeli itp. Tam mogą być tylko identyfikatory. Argumenty bezpośrednio do zapytania można wpisać tylko tam, gdzie normalnie byś wpisywał gotowe wartości. Sam fakt, że czegoś takiego potrzebujesz daje do myślenia nad strukturą bazy. Jeśli jednak koniecznie chcesz to zrobić to musisz pomóc sobie klejonym preparowanym zapytaniem:
hmm, wyglada to dosc skomplikowanie... poczytam na temat elementow, ktorych nie znam... jak prepare, czy execute (nigdy tego nie uzywalem)... napisales, ze trzeba pomyslec nad struktura bazy... moze faktycznie ja zle do tego podchodze... jednak to co robie jest dosc nietypowe i problem rozwiazuje obecnie w php (co nie jest moze optymalne, ale w sql tego jeszcze nie umiem), chodzi o to, ze trzeba powyciagac wartosci z roznych widokow i to powywracanych na rozne strony w zaleznosci od parametrow i zaleznosci miedzy tym parametrami (np. czy dodatni czy ujemny, czy argumenty podano alfabetycznie czy nie itd), a robienie odpowiednich joinow w teorii by dzialalo, ale jak to napisalem to zajelo kilkadziesiat linii (pelno dlugich (bo precyzyjnych) aliasow i do tego gdzies wkradl sie bug i uznalem, ze albo musze sie nauczyc procedur, albo zrobie to w php... ze czas naglil, to zrobilem w php, ale procedur i tak sie chce nauczyc i wlasnie utknalem na tych argumentach w zapytaniach ![]() dzieki, bede to analizowal... EDIT jednak nie jest to az tak skomplikwane jak wygladalo na pierwszy rzut oka i da sie to ogarnac ![]() k. Ten post edytował phoenix84 4.10.2013, 17:33:16 |
|
|
![]() ![]() |
![]() |
Aktualny czas: 19.08.2025 - 07:33 |