Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Pobieranie kilku wartości, z tablicy typu: nazwa parametru, wartość
L_Devil
post
Post #1





Grupa: Zarejestrowani
Postów: 195
Pomógł: 0
Dołączył: 13.04.2004
Skąd: Łódź

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


Witam!

Mam następujący problem: mam tablicę która ma dwa pola:

Nazwa parametru i jego wartość

Wartość jest zawsze numeryczna. Chciałbym teraz pobrać kilka wartości - robienie kilku zapytań to oczywiście głupota i strata czasu procesora, więc pomyślałem o zapytaniu
  1. SELECT wartosc
  2. FROM tabela WHERE nazwa='cena' OR nazwa='podatek' OR nazwa='zysk';
I tutaj mam problem - w odpowiedzi SQL przysyła trzy liczby. Skąd mam wiedzieć która jest z której nazwy parametru?

Drugie pytanie. Chciałbym teraz updatetować te kilka informacji na raz. Czy i jak da się to zrobić?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 7)
kszychu
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 2 712
Pomógł: 23
Dołączył: 27.10.2003
Skąd: z kontowni

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


SELECT nazwa, wartosc ..... i już wiesz co jest co (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
nospor
post
Post #3





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Cytat
Drugie pytanie. Chciałbym teraz updatetować te kilka informacji na raz. Czy i jak da się to zrobić?

  1. UPDATE tabela SET wartosc = nowawartosc WHERE nazwa='cena' OR nazwa='podatek' OR nazwa='zysk';


Co do pierwszego co juz otrzymales prawidłową odpowiedź od kszycha to napisze, bo sie powstrzymac nie moge: patrz podpis poniżej. To sie naprawde przydaje
Go to the top of the page
+Quote Post
L_Devil
post
Post #4





Grupa: Zarejestrowani
Postów: 195
Pomógł: 0
Dołączył: 13.04.2004
Skąd: Łódź

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


No tak do tego pierwszego nie pomyślałem...

ale to drugie niestety nie jest tym o co mi chodzi:

tzn.

chciałbym w polu 'cena' dać wartość np. 100, w polu 'podatek' np. 22, w polu 'zysk' np. 78 i to wszystko w jednym zapytaniu
Go to the top of the page
+Quote Post
nospor
post
Post #5





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




Ja może teraz troche odbiene od tematu, ale mnie to interesuje.
Czy te trzy rekordy z cena, podatek i zysk odnoszą się do jednego? Jesli tak to rekordy powinny byc polami w rtekordzie, a nie kolejnymi rekordami

tabela:
id, cena, podatek, zysk, pozostale pola
Go to the top of the page
+Quote Post
L_Devil
post
Post #6





Grupa: Zarejestrowani
Postów: 195
Pomógł: 0
Dołączył: 13.04.2004
Skąd: Łódź

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


te rekordy typu 'cena', itp. to były tylko przykłady (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg) Jest po prostu n wartości numerycznych w tabeli, przy czym trzeba uwazględnić że liczba n nie jest const. więc nie mogę zrobić tabeli na n-pól. No i n może mieć nawet wartość nawet kilkaset - tabela z taką ilością pól chyba się mija z celem, zwłaszcza że co chwilę trzeba będzie dodawać jakieś pole, lub usuwać zbędne.
Dlatego ponawiam pytanie - jak updeatować kilka rekordów jednym zapytaniem?
Go to the top of the page
+Quote Post
nospor
post
Post #7





Grupa: Moderatorzy
Postów: 36 557
Pomógł: 6315
Dołączył: 27.12.2004




W tym przypadku co podales:
  1. UPDATE tabela SET wartosc = IF(nazwa = 'cena',100,IF(nazwa='podatek',22,78)) WHERE nazwa='cena' OR nazwa='podatek' OR nazwa='zysk'
Go to the top of the page
+Quote Post
L_Devil
post
Post #8





Grupa: Zarejestrowani
Postów: 195
Pomógł: 0
Dołączył: 13.04.2004
Skąd: Łódź

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


Dzięki (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
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 - 20:33