Tidak (kecuali ada bug serius di Oracle atau kecuali kita berbicara tentang transaksi terdistribusi).
Jika koneksi antara klien dan database terputus, kemungkinan database tidak pernah menerima permintaan untuk melakukan transaksi. Dalam hal ini, setelah database menemukan bahwa klien sudah mati (yang mungkin memakan waktu lama), transaksi akan dibatalkan. Jika koneksi terputus, ada kemungkinan database berhasil melakukan tetapi klien tidak pernah mendapat pemberitahuan bahwa komit berhasil.
Jika kita berbicara tentang transaksi terdistribusi, ada kemungkinan bahwa transaksi tersebut tetap diragukan pada satu (atau lebih) node terdistribusi. Jika demikian, transaksi akan muncul di dba_2pc_pending
pada node di mana transaksi masih tertunda. Tapi itu tidak akan dilakukan sebagian pada node mana pun.
Jika saya harus menebak, jika Anda melihat sesuatu yang "berkomitmen sebagian", saya berani bertaruh bahwa masalahnya adalah batas transaksi Anda tidak benar dan Anda memiliki beberapa kode di suatu tempat yang melakukan (secara implisit atau eksplisit) di tempat yang tidak Anda duga.