Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

स्ट्रीमिंग परिणाम सेट को बंद करना (mysql jdbc का उपयोग करके) एक लंबा समय लेता है

तो जैसा कि प्रश्न पर मेरी टिप्पणी में पोस्ट किया गया है, MySQL कनेक्टर से आधिकारिक उत्तर यह है कि आपको इसे बंद करने के लिए सेट किए गए सभी परिणामों को स्ट्रीम करना होगा (http://dev.mysql.com/doc/refman/5.5/en/connector-j- संदर्भ-कार्यान्वयन-नोट्स.html ) इसके अतिरिक्त, स्ट्रीमिंग परिणाम होने के दौरान आप कोई और क्वेरी नहीं कर सकते।

पूरी तरह से घृणित हैक के रूप में, मैंने नीचे जाने के लिए प्रतिबिंब का उपयोग किया RowDataDynamic (ver. 5.1.24) और नकली एक बाधित अपवाद, जैसे:

    final Class<?> rdClass = rd.getClass();
    final Field isInterruptedField = rdClass.getDeclaredField("isInterrupted");
    isInterruptedField.setAccessible(true);  // override 'protected' visibility
    isInterruptedField.set(rd, true);

ध्यान दें, ResultSet पर जाने के लिए आपको जो भी ऑब्जेक्ट हैंडल करना है, उसे नीचे ले जाना होगा। मेरे लिए, मैं हाइबरनेट की स्क्रॉल करने योग्य परिणाम कक्षा का उपयोग कर रहा था। इसका मतलब था इससे परिणामसेट संदर्भ प्राप्त करना (इसकी सुपर क्लास, वास्तव में), फिर वहां से RowData।

यह शेष परिणामों को स्ट्रीम किए बिना क्लोज ऑपरेशन की अनुमति देगा फिर भी जब मैं लेन-देन को रोलबैक करने का प्रयास करता हूं (जिसे मैं अभी पकड़ता हूं और अनदेखा करता हूं) बेमेल पैकेट आकार के कारण मुझे अपवाद मिलता है। Atomikos को कनेक्शन पूल के रूप में उपयोग करते हुए, जैसे-जैसे चीज़ें साफ़ होंगी, मुझे अगले कुछ कनेक्शनों के बारे में चेतावनियाँ दिखाई देंगी, लेकिन सब कुछ अभी भी ठीक काम करता है।

स्पष्ट रूप से यह दृष्टिकोण सभी के लिए काम नहीं कर सकता है, लेकिन कम से कम यह एक समाधान है जब डेटाबेस क्वेरी के माध्यम से प्रसंस्करण करना या बैचों में परिणाम पुनर्प्राप्त करने के लिए अधिक जटिल तर्क लिखना काम नहीं करेगा।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL एक चर के साथ उपयोगकर्ता बनाएँ?

  2. SQL सिंटैक्स त्रुटि - Haversine सूत्र

  3. डेटाबेस मानों को जोड़ने में मदद चाहिए

  4. बाइनरी लॉग फ़ाइल से डेटा कैसे प्राप्त करें और MySQL में हमारी वांछित तालिका में डालें?

  5. 2017 @ कईनाइन्स:सेलिब्रेटिंग अवर कस्टमर स्टोरीज