Jak inkrementować lub dekrementować wartość mysql w jednym zapytaniu ?: Różnice pomiędzy wersjami

Z Podręcznik Administratora by OPZ SGU
Przejdź do nawigacji Przejdź do wyszukiwania
m (Zastępowanie tekstu - "<source lang="php">" na "<pre>")
m (Zastępowanie tekstu - "</source>" na "</pre>")
 
Linia 4: Linia 4:
<pre>
<pre>
UPDATE tabela SET licznik=licznik+1 WHERE id=5
UPDATE tabela SET licznik=licznik+1 WHERE id=5
</source>
</pre>




Linia 15: Linia 15:
$st->bindParam(":id",$test['id']);
$st->bindParam(":id",$test['id']);
$st->execute();
$st->execute();
</source>
</pre>


Dekrementacja
Dekrementacja
Linia 24: Linia 24:
$st->bindParam(":id",$test['id']);
$st->bindParam(":id",$test['id']);
$st->execute();
$st->execute();
</source>
</pre>


[[Category:MySQL]]
[[Category:MySQL]]
[[Category:PHP]]
[[Category:PHP]]

Aktualna wersja na dzień 17:23, 15 lut 2018

Czasami zachodzi konieczność stworzenia szybkiego licznika, w tym celu wystarczy

Czyste zapytanie mysql

UPDATE tabela SET licznik=licznik+1 WHERE id=5


Zapytanie z PDO

Inkrementacja

$sql = "UPDATE tabela SET licznik=licznik+1 WHERE id=:id";
$st = $dbh->prepare($sql);
$st->bindParam(":id",$test['id']);
$st->execute();

Dekrementacja

$sql = "UPDATE tabela SET licznik=licznik-1 WHERE id=:id";
$st = $dbh->prepare($sql);
$st->bindParam(":id",$test['id']);
$st->execute();