sql >> Databasteknik >  >> RDS >> Mysql

MySQL atomoperationer och bordslåsning

Du är väldigt nära din design, men inte riktigt där.

Först och främst måste ditt evenemangsbord innehålla det antal biljetter som fortfarande är tillgängliga för ditt evenemang (utöver vad du vill ha där).

För det andra måste din depositionstabell ha en DATETIME-kolumn som anger när depositionen löper ut. Du måste ställa in det värdet när biljetter går in i deposition.

För det tredje måste transaktionen med att sätta biljetter i deposition

  1. lås händelseraden.
  2. läs kolumnen för tillgängliga biljetter. (avbryt om det inte finns tillräckligt många tillgängliga)
  3. infoga en rad i spärrtabellen
  4. uppdatera händelseraden för att minska kolumnen för tillgängliga biljetter.
  5. lås upp händelseraden.

För det fjärde måste åtgärden för att slutföra försäljningen radera depositionsraden och infoga en såld biljettrad. Det här är inte svårt.

För det femte behöver du en depositionsrensning. Detta måste leta efter alla spärrade rader som har löpt ut (som har ett utgångsdatum i det förflutna) och för var och en:

  1. lås motsvarande händelserad.
  2. läs antalet deponerade biljetter från depositionstabellen
  3. ta bort depositionstabellraden.
  4. uppdatera händelseraden för att öka kolumnen för tillgängliga biljetter.
  5. lås upp händelseraden.

Tricket är att ha antalet tillgängliga biljetter underhålls på ett sätt som är korrekt låsta, så att tävlingsförhållandena mellan användare inte översäljer ditt evenemang.




  1. Finns det en gräns för antalet tabeller i en SQL Server-databas OCH -vy?

  2. Hur man infogar en rad data i mysql med php

  3. Implementera inkrementella klientuppdateringar med radversioner i Postgres

  4. SQL Server:Användbara tips för nybörjare