Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Transakcje Atomic MySQL w Anorm

Użyj withTransaction zamiast withConnection tak:

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()
  }
}

A dlaczego miałbyś w ogóle skorzystać z transakcji tutaj? To również powinno działać:

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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. pogrupować dokładne wartości Tandem z 2 kolumny?

  2. MySQL - jak wyświetlić najnowszy temat na wątek

  3. Wydajność UUID w MySQL?

  4. Jak odzyskać dane mysql za pomocą wielowątkowości Java?

  5. Uzupełnij brakujące luki w zapytaniu o zakres dat za pomocą tabeli kalendarza