Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> UPDATE + CASE i WHEN
wujek2009
post 10.07.2011, 16:36:08
Post #1





Grupa: Zarejestrowani
Postów: 350
Pomógł: 31
Dołączył: 23.05.2010

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


Hej, potrzebuje pomocy przy sformułowaniu zapytania aktualizującą tabele konfiguracyjną.
Wiem, że można zrobić oddzielnym zapytaniem dla każdej wartości, ale wtedy będę miał np. 20 zapytań (bądź więcej w zależności od ilości ustawień) a pamiętam, że istnieje aktualizacja rekordów za pomocą CASE + WHEN.

  1. UPDATE configuration SET
  2. case value = 'nowa wartosc'
  3. when variable = 'site_name'
  4. case value = 'druga wartosc'
  5. when variable = 'site_mail'


W odpowiedzi dostaje mysql error;
Kod
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'case value = 'nowa wartosc' when variable = 'site_name' case value = 'druga ' at line 2


Ten post edytował wujek2009 10.07.2011, 16:36:43
Go to the top of the page
+Quote Post
toaspzoo
post 10.07.2011, 16:38:53
Post #2





Grupa: Zarejestrowani
Postów: 778
Pomógł: 84
Dołączył: 29.07.2010
Skąd: Gliwice / Pławniowice Mistrz niezmordowanej klawiatury.

Ostrzeżenie: (20%)
X----


a przecinki ?

Kod
    UPDATE configuration SET
    case value = 'nowa wartosc',
    when variable = 'site_name',
    case value = 'druga wartosc',
    when variable = 'site_mail'


--------------------

LS Easter egg <
Go to the top of the page
+Quote Post
wujek2009
post 10.07.2011, 16:43:01
Post #3





Grupa: Zarejestrowani
Postów: 350
Pomógł: 31
Dołączył: 23.05.2010

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


Nie, problem nie polega na braku przecinków w aktualnym stanie jaki przedstawiłem w pierwszym poście. Otrzymałem ponownie mysql error ten sam co w pierwszym poście.
Go to the top of the page
+Quote Post
skowron-line
post 10.07.2011, 16:53:40
Post #4





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


A widziałeś kiedyś manuala na oczy questionmark.gif http://dev.mysql.com/doc/refman/5.0/en/con...l#operator_case


--------------------
I'm so fast that last night I turned off the light switch in my hotel room and was in bed before the room was dark - Muhammad Ali.
Peg jeżeli chcesz uprawiać sex to dzieci muszą wyjść, a jeżeli chcesz żeby był dobry ty też musisz wyjść - Al Bundy.

QueryBuilder, Mootools.net, bbcradio1::MistaJam
http://www.phpbench.com/
Go to the top of the page
+Quote Post
mortus
post 10.07.2011, 17:01:38
Post #5





Grupa: Zarejestrowani
Postów: 2 178
Pomógł: 596
Dołączył: 25.09.2009
Skąd: Piwniczna-Zdrój

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


Chyba, jak to manual pokazuje, instrukcja CASE wygląda nieco inaczej w MySQL:
  1. UPDATE configuration SET
  2. `value` = (CASE `variable`
  3. WHEN 'site_name' THEN 'nowa wartość'
  4. WHEN 'site_email' THEN 'druga nowa wartość'
  5. END)
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 19.07.2025 - 01:39