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
m (Zastępowanie tekstu - "<source lang="php">" na "<pre>")
Linia 2: Linia 2:


Czyste zapytanie mysql
Czyste zapytanie mysql
<source lang="php">
<pre>
UPDATE tabela SET licznik=licznik+1 WHERE id=5
UPDATE tabela SET licznik=licznik+1 WHERE id=5
</source>
</source>
Linia 10: Linia 10:


Inkrementacja
Inkrementacja
<source lang="php">
<pre>
$sql = "UPDATE tabela SET licznik=licznik+1 WHERE id=:id";
$sql = "UPDATE tabela SET licznik=licznik+1 WHERE id=:id";
$st = $dbh->prepare($sql);
$st = $dbh->prepare($sql);
Linia 19: Linia 19:
Dekrementacja
Dekrementacja


<source lang="php">
<pre>
$sql = "UPDATE tabela SET licznik=licznik-1 WHERE id=:id";
$sql = "UPDATE tabela SET licznik=licznik-1 WHERE id=:id";
$st = $dbh->prepare($sql);
$st = $dbh->prepare($sql);

Wersja z 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
</source>


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();
</source>

Dekrementacja

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