Mysql
 sql >> Teknologi Basis Data >  >> RDS >> Mysql

Transaksi MySQL Atom di Anorm

Gunakan withTransaction alih-alih withConnection seperti ini:

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

Dan mengapa Anda bahkan menggunakan transaksi di sini? Ini juga harus berfungsi:

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. PHP - Akses MySQL ditolak kesalahan - Bekerja di program lain

  2. Bagaimana cara InnoDB menyimpan kolom karakter?

  3. Bagaimana cara membuat kueri yang aman untuk melakukan penyisipan massal di MySQL menggunakan MySQLCommand di C# tanpa menggunakan proc yang tersimpan?

  4. mysqli::query():Tidak dapat mengambil mysqli

  5. Dalam SQL bagaimana cara mendapatkan nilai maksimum untuk bilangan bulat?