Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [MySQL]Proste działania matematyczne przy UPDATE, Można zastosować skróty jak w PHP np. col+=1 ??
Welon
post 31.01.2010, 19:23:45
Post #1





Grupa: Zarejestrowani
Postów: 2
Pomógł: 0
Dołączył: 1.01.2010

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


Tak jak w opisie.
Zastanawiam się, czy są możliwe jakieś skróty matematyczne przy funkcji UPDATE jak w JS czy PHP np. var+=2 daje nam to samo co var=var+2. albo var++ daje to samo co var=var+1.
Go to the top of the page
+Quote Post
skowron-line
post 31.01.2010, 20:42:56
Post #2





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

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


A próbowałeś któreś z tych zastosować questionmark.gif Po co pytasz skoro możesz sam sobie sprawdzić.


--------------------
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
cojack
post 1.02.2010, 09:46:52
Post #3





Grupa: Zarejestrowani
Postów: 898
Pomógł: 80
Dołączył: 31.05.2008

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


Nie możesz tak zrobić na samym select. Coś takiego można by zrobić w pl/sql a dokładniej w pl/pgsql (bo ten znam) np:


  1. CREATE FUNCTION "someTableUpdateFunction" RETURNS TRIGGER AS $BODY$
  2. BEGIN
  3. NEW."someField" := OLD."someField" + 2;
  4. RETURN NEW;
  5. END;
  6. $BODY$ LANGUAGE 'plpgsql';
  7.  
  8. CREATE TRIGGER "someTableUpdateTrigger"
  9. BEFORE UPDATE ON "someTable"
  10. FOR EACH ROW EXECUTE PROCEDURE "someTableUpdateFunction"();


I gra muzyka.


@edit
yhy widzę że z armatą na wróbla wyskakuje, ehh takie proste rzeczy mi z bania wywala ;]

Ten post edytował cojack 1.02.2010, 11:19:54


--------------------
cojack blog - mój blog (na jakiś czas off).
"jak czegoś nie wiem, to nie myślę że wiem" - moja domena
Go to the top of the page
+Quote Post
VGT
post 1.02.2010, 10:59:22
Post #4





Grupa: Zarejestrowani
Postów: 63
Pomógł: 9
Dołączył: 19.11.2004
Skąd: Iława

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


  1. UPDATE `tabela` SET `pole` = `pole` + 1 WHERE `inne_pole` = "oczekiwane" LIMIT 1;


Ten post edytował VGT 1.02.2010, 11:03:23
Go to the top of the page
+Quote Post
kefirek
post 1.02.2010, 11:02:28
Post #5





Grupa: Zarejestrowani
Postów: 781
Pomógł: 256
Dołączył: 29.06.2008

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


  1. SET @nr = 0;
  2. UPDATE tabela SET kolumna = @nr:=@nr+1


Ten post edytował kefirek 1.02.2010, 11:03:51
Go to the top of the page
+Quote Post
Welon
post 2.02.2010, 23:48:08
Post #6





Grupa: Zarejestrowani
Postów: 2
Pomógł: 0
Dołączył: 1.01.2010

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


Cytat(skowron-line @ 31.01.2010, 20:42:56 ) *
A próbowałeś któreś z tych zastosować questionmark.gif Po co pytasz skoro możesz sam sobie sprawdzić.

Próbowałem i nie działają. ;]
Dlatego pytam czy jest JAKIŚ sposób.
Ja właśnie robię to cały czas jak VGT.
Cytat(VGT @ 1.02.2010, 10:59:22 ) *
  1. UPDATE `tabela` SET `pole` = `pole` + 1 WHERE `inne_pole` = "oczekiwane" LIMIT 1;

z tym że nie pomyślałem, żeby dodać LIMIT. Dzięki za sugestię. ;]
Go to the top of the page
+Quote Post
VGT
post 3.02.2010, 11:32:16
Post #7





Grupa: Zarejestrowani
Postów: 63
Pomógł: 9
Dołączył: 19.11.2004
Skąd: Iława

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


Akurat limit to juz kosmetyka, jesli sekcja where zapewnia uwzglednienie tylko jednego rekordu. winksmiley.jpg Ja akurat dodaje go z przyzwyczajenia nawet w selectach, ktore wyciagaja cos po kluczu glownym.

Sadzilem, ze tego nie znasz i ogolnie pytasz, gdyz nie zakladalem, ze mozna jeszcze dalej szukac usprawnien w stylu: set `pole`++ smile.gif

Ten post edytował VGT 3.02.2010, 11:33:29
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: 28.04.2025 - 08:34