Vorwort Vor kurzem habe ich aus beruflichen Gründen an der Bezahlung von Bestellungen im Warenkorb der APP gearbeitet. Beim Testen wurde ein Fehler festgestellt. Als ich schnell auf „In den Warenkorb“ klickte, erschien dasselbe Produkt zweimal im Warenkorb. Denn beim Hinzufügen in den Warenkorb gibt es zwei Schritte. Im ersten Schritt wird festgestellt, ob das in den Warenkorb zu legende Produkt bereits im Warenkorb liegt. Wenn ja, wird zur ursprünglichen Menge eins hinzugefügt. Wenn nicht, wird es erneut hinzugefügt. Da es sich bei den beiden Schritten nicht um atomare Operationen handelt, gibt es ein Multithread-Sicherheitsproblem. Ich werde im Folgenden nicht viel dazu sagen. Folgen wir dem Editor, um den detaillierten Lösungsprozess anzusehen, der Ihnen eine gewisse Hilfe sein wird. MySQL Insert verfügt über eine erweiterte Operation Beispielcode: INSERT INTO t_xs_shopping_cart ( Benutzer-ID, Shop-ID, Waren-ID, Menge ) WERTE (71, 67, 140201057403511024, 1) BEIM UPDATE DES DUPLIZIERTEN SCHLÜSSELS Menge = Menge + 1 Wenn die eindeutige Schlüsselbeschränkung wirksam wird, wird die Update-Anweisung ausgeführt, um die Menge um 1 zu erhöhen Zusammenfassen Das Obige ist der vollständige Inhalt dieses Artikels. Ich hoffe, dass der Inhalt dieses Artikels Ihnen bei Ihrem Studium oder Ihrer Arbeit helfen kann. Wenn Sie Fragen haben, können Sie eine Nachricht hinterlassen. Vielen Dank für Ihre Unterstützung von 123WORDPRESS.COM. Das könnte Sie auch interessieren:
|
<<: Was ist dies in einer Punkt-für-Punkt-Reihe von JavaScript?
>>: Beispielcode zum Konvertieren von Videos mit der ffmpeg-Befehlszeile
Durch das Studium und die Anwendung von Node wiss...
Vorwort Bei der Linux-Kernel-Programmierung werde...
Inhaltsverzeichnis Beschränkung der Bezeichnerlän...
1. Versuchen Sie, ein einspaltiges statt eines meh...
Dieser Artikel erläutert anhand von Beispielen di...
1. Vermeiden Sie es, die Seite als XML-Typ zu dek...
1. Reinigen Sie vor der Installation gründlich rp...
Inhaltsverzeichnis Einführung Installieren 1. Ers...
Inhaltsverzeichnis 1. Docker-Installation auf dem...
(1) Reduzieren Sie HTTP-Anfragen. (Ressourcendate...
Ich hatte dieses Problem in letzter Zeit beim Desi...
Tatsächlich ist es nicht schwierig, einen Apache-...
1 Behalten Sie das RPM-Paket bei, das heruntergel...
1. Gründe Wenn das System Centos7.3 ist, ist die ...
beschreiben Gibt das Zeitintervall zwischen zwei ...