Heim >Datenbank >MySQL-Tutorial >Wie erhöhe ich den Wert eines MySQL-Datenbankfelds um 1?

Wie erhöhe ich den Wert eines MySQL-Datenbankfelds um 1?

DDD
DDDOriginal
2024-12-16 21:11:19865Durchsuche

How to Increment a MySQL Database Field's Value by 1?

Datenbankfelder inkrementieren

Problem:

Wie erhöhen Sie in MySQL? ein Datenbankfeld, z. B. „logins“, mit einem SQL-Befehl um 1 erweitern? Stellen Sie sich eine Tabelle vor, die die Spalten „firstName“, „lastName“ und „logins“ enthält. Das Ziel besteht darin, eine Abfrage zu erstellen, die neue Personen einfügt oder bestehende Anmeldungen für bestimmte Namen erhöht.

Lösung:

Einen Eintrag aktualisieren:

Um ein vorhandenes Anmeldefeld zu erhöhen, verwenden Sie ein SQL-Update Anweisung:

UPDATE mytable 
SET logins = logins + 1 
WHERE id = 12

Neue Zeile einfügen oder doppelte Zeile aktualisieren:

Um vorhandene Namen zu aktualisieren oder neue einzufügen, verwenden Sie entweder die REPLACE-Syntax oder INSERT ...AUF DUPLICATE KEY UPDATE Option:

-- REPLACE Syntax
REPLACE INTO mytable (firstName, lastName, logins)
VALUES ('Tom', 'Rogers', 1)

-- INSERT ... ON DUPLICATE KEY UPDATE
INSERT INTO mytable (firstName, lastName, logins)
VALUES ('Tom', 'Rogers', 1)
ON DUPLICATE KEY UPDATE logins = logins + 1

Einfügen eines neuen Eintrags:

Um beim Einfügen eine neue Anmeldeanzahl zuzuweisen, sollten Sie die Verwendung einer Unterabfrage in Betracht ziehen:

INSERT into mytable (logins) 
SELECT max(logins) + 1 
FROM mytable

Das obige ist der detaillierte Inhalt vonWie erhöhe ich den Wert eines MySQL-Datenbankfelds um 1?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn