php - Adakah mungkin pertanyaan dan perubahan data mysql berlaku pada masa yang sama?
大家讲道理
大家讲道理 2017-05-16 13:04:36
0
5
455

Oleh kerana saya ingin melakukan proses serentak (konkurensi di sini ialah konkurensi kecil, iaitu, konkurensi beberapa orang), pentadbir latar belakang mengendalikan sekeping data pembayaran balik untuk menghalang beberapa pengurus daripada mengendalikan satu bahagian pada masa yang sama tanpa disedari pembayaran balik, ralat berlaku.

Pendekatan saya ialah menambah lock_time medan pada jadual dan menanyakan data yang lock_time adalah sama dengan 0. Selepas menanyakannya, tukar lock_time kepada masa semasa (saya menambah lock_time=0 sebagai keadaan di mana semasa kemas kini).

Soalan: Adakah terdapat sebarang kesesuaian jika saya melakukan ini?

Maksudnya, di bawah persekitaran yang ideal, dua orang boleh menanyakan sekeping data pada masa yang sama (menanya "secara serentak" dalam masa seminit atau saat),

Begitu juga, adakah mungkin untuk dua orang menukar medan tertentu bagi sekeping data pada masa yang sama (ditukar "pada masa yang sama" dalam masa seminit atau saat),

大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

membalas semua(5)
为情所困

Jawapan kepada soalan anda adalah mungkin. Anda harus menggunakan kunci dan transaksi untuk mengelakkan masalah ini dan bukannya menggunakan medan baharu

滿天的星座

Baidu innodb kunci sudah memadai.

黄舟

Anda boleh melihat konsep penguncian optimistik. Tambahkan medan nombor versi, anda boleh mengabaikannya semasa membaca data, menyemak nombor versi semasa mengemas kini data dan mengemas kini nombor versi. Perbezaan antara nombor versi dan lock_time anda ialah pendua mungkin berlaku jika lock_time tidak cukup tepat Nombor versi sentiasa +1 dan tiada masalah versi pendua

小葫芦

Kunci dan barang-barang hendaklah dapat memenuhi keperluan anda. Mari kita lihat dengan lebih dekat kedua-dua konsep Mysql ini.

我想大声告诉你

Idea anda hampir kepada penguncian optimistik Tukar lock_time kepada cap waktu untuk pengesahan. Ia juga mungkin untuk menggunakan kunci baris InnoDB untuk konkurensi kecil, dan pada dasarnya tiada kesukaran prestasi.

Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan