Mengesan Komit atau Rollback dalam Transaksi Pangkalan Data
Ia boleh mencabar untuk menentukan status transaksi dalam pangkalan data/sql tanpa melaksanakan transaksi lain dan meneliti ralat yang terhasil. Pendekatan ini memerlukan kerumitan tambahan dan pertindihan kod.
Sebaliknya, adalah disyorkan untuk mengamalkan amalan berikut:
1. Merangkumkan Transaksi dalam Fungsi:
Keep Begin(), Commit(), dan Rollback() dalam fungsi yang sama. Ini memudahkan pengendalian transaksi dan memastikan penutupan yang betul menggunakan penangguhan. Pertimbangkan contoh berikut:
func DoSomething() (err error) { tx, err := s.db.Begin() if err != nil { return } defer func() { if err != nil { tx.Rollback() return } err = tx.Commit() }() // Transaction operations... return }
2. Gunakan Pengendali Transaksi:
Memudahkan pengendalian transaksi dengan lebih lanjut dengan merangkum logik dalam pengendali transaksi:
func Transact(db *sql.DB, txFunc func(*sql.Tx) error) (err error) { // Transaction handling and error handling logic... }
Ini membolehkan kod transaksi ringkas:
DoSomething() error { return Transact(s.db, func (tx *sql.Tx) error { // Transaction operations... return nil }) }
3. Mengendalikan Panik dan Pertimbangan GC:
Dalam pengendali transaksi, gunakan recover() untuk menangkap panik dan memastikan Rollback berlaku. Buang semula panik jika perlu.
Bagi GC dan pemulihan memori, tetapan pembolehubah Tx kepada sifar selepas Commit atau Rollback adalah tidak perlu. GC akan menuntut semula sebarang sumber yang tidak digunakan.
Dengan mematuhi amalan terbaik ini, anda boleh mengesan dan mengendalikan status transaksi dengan berkesan dalam aplikasi pangkalan data/sql anda.
Nota Tambahan:
Elakkan menggunakan panik sebagai mekanisme pengendalian ralat biasa. Sentiasa bertujuan untuk mengembalikan ralat untuk membolehkan pengendalian yang betul oleh kod pemanggil.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengesan Status Komit atau Rollback dengan Amanah dalam Transaksi Pangkalan Data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!