sql >> Database teknologi >  >> RDS >> Mysql

Atomic MySQL transaktioner i Anorm

Brug withTransaction i stedet for withConnection sådan her:

private def incrementHitCounter(urlName:String) {
  DB.withTransaction { implicit connection =>
    SQL("select @hits:=hits from content_url_name where url_name={urlName};").on("urlName" -> urlName).apply()
    SQL("update content_url_name set hits = @hits + 1 where url_name={urlName};").on("urlName" -> urlName).executeUpdate()
  }
}

Og hvorfor ville du overhovedet bruge en transaktion her? Dette burde også virke:

private def incrementHitCounter(urlName:String) {
  DB.withConnection { implicit connection =>
    SQL("update content_url_name set hits = (select hits from content_url_name where url_name={urlName}) + 1 where url_name={urlName};").on("urlName" -> urlName).executeUpdate()
  }
}



  1. Ændring af en søjletype til længere strenge i skinner

  2. Dublet unicode-indtastningsfejl på den unikke kolonne - mysql

  3. MySQL:summer datotider uden at tælle overlappende perioder to gange

  4. Postgres - Funktion til at returnere skæringspunktet mellem 2 ARRAY'er?