Setelah banyak pengujian, kami telah memperbaiki masalah ini. Ini adalah kombinasi dari bagaimana kami menggunakan kerangka pegas dan klien oracle dan oracle DB. Kami sedang membuat SimpleJDBCCalls baru yang menggunakan panggilan metadata klien JDBC Oracle yang dikembalikan sebagai kursor yang tidak ditutup dan dibersihkan. Saya menganggap ini sebagai bug dalam kerangka Spring JDBC dalam cara memanggil metadata tetapi kemudian tidak menutup kursor. Spring harus menyalin data meta dari kursor dan menutupnya dengan benar. Saya tidak repot-repot membuka masalah jira dengan pegas karena jika Anda menggunakan praktik terbaik, bug tidak ditampilkan.
Mengubah OPEN_CURSORS atau parameter lainnya adalah cara yang salah untuk memperbaiki masalah ini dan hanya menunda kemunculannya.
Kami mengatasinya/memperbaikinya dengan memindahkan SimpleJDBCCall ke DAO tunggal sehingga hanya ada satu kursor yang terbuka untuk setiap proc Oracle yang kami panggil. Kursor ini terbuka untuk masa pakai aplikasi - yang saya anggap sebagai bug. Selama OPEN_CURSORS lebih besar dari jumlah objek SimpleJDBCCall maka tidak akan ada kerepotan.