JDBC - परिणाम सेट

SQL कथन जो डेटाबेस क्वेरी से डेटा पढ़ते हैं, परिणाम सेट में डेटा वापस करते हैं। SELECT स्टेटमेंट एक डेटाबेस से पंक्तियों को चुनने और उन्हें परिणाम सेट में देखने का मानक तरीका है। Java.sql.ResultSet इंटरफ़ेस एक डेटाबेस क्वेरी के परिणाम सेट का प्रतिनिधित्व करता है।

ResultSet ऑब्जेक्ट एक कर्सर रखता है जो परिणाम सेट में वर्तमान पंक्ति को इंगित करता है। "परिणाम सेट" शब्द एक परिणामी वस्तु में निहित पंक्ति और स्तंभ डेटा को संदर्भित करता है।

ResultSet इंटरफ़ेस के तरीकों को तीन श्रेणियों में तोड़ा जा सकता है -

  • Navigational methods: कर्सर को इधर-उधर करने के लिए उपयोग किया जाता है।

  • Get methods: कर्सर द्वारा इंगित की जा रही वर्तमान पंक्ति के कॉलम में डेटा देखने के लिए उपयोग किया जाता है।

  • Update methods:वर्तमान पंक्ति के कॉलम में डेटा को अपडेट करने के लिए उपयोग किया जाता है। फिर अपडेट अंतर्निहित डेटाबेस में भी अपडेट किया जा सकता है।

ResultSet के गुणों के आधार पर कर्सर जंगम है। ये गुण तब निर्दिष्ट किए जाते हैं जब संबंधित विवरण जो परिणाम उत्पन्न करता है, बनाया जाता है।

JDBC वांछित रिजल्टसेट के साथ स्टेटमेंट बनाने के लिए निम्नलिखित कनेक्शन विधि प्रदान करता है -

  • createStatement(int RSType, int RSConcurrency);

  • prepareStatement(String SQL, int RSType, int RSConcurrency);

  • prepareCall(String sql, int RSType, int RSConcurrency);

पहला तर्क रिजल्टसेट ऑब्जेक्ट के प्रकार को इंगित करता है और दूसरा तर्क यह निर्दिष्ट करने के लिए दो रिजल्टसेट स्थिरांक में से एक है कि क्या परिणाम सेट केवल पढ़ने योग्य है या अद्यतन करने योग्य है।

परिणाम का प्रकार

संभावित RSType नीचे दिए गए हैं। यदि आप किसी भी परिणाम प्रकार को निर्दिष्ट नहीं करते हैं, तो आपको स्वचालित रूप से वह मिलेगा जो TYPE_FORWARD_ONLY है।

प्रकार विवरण
ResultSet.TYPE_FORWARD_ONLY परिणाम सेट में कर्सर केवल आगे बढ़ सकता है।
ResultSet.TYPE_SCROLL_INSENSITIVE कर्सर आगे और पीछे स्क्रॉल कर सकता है, और परिणाम सेट दूसरों के द्वारा डेटाबेस में किए गए परिवर्तनों के प्रति संवेदनशील नहीं है, जो परिणाम सेट के बाद उत्पन्न होता है।
ResultSet.TYPE_SCROLL_SENSITIVE। कर्सर आगे और पीछे की ओर स्क्रॉल कर सकता है, और परिणाम सेट दूसरों के द्वारा डेटाबेस में किए गए परिवर्तनों के लिए संवेदनशील है जो परिणाम सेट के बाद उत्पन्न होता है।

परिणाम की सम्‍भावना

संभव RSConcurrency नीचे दिया गया है। यदि आप किसी भी संगामिति प्रकार को निर्दिष्ट नहीं करते हैं, तो आप स्वचालित रूप से एक प्राप्त करेंगे जो CONCUR_READ_ONLY है।

संगामिति विवरण
ResultSet.CONCUR_READ_ONLY केवल-पढ़ने के लिए सेट परिणाम बनाता है। यह डिफ़ॉल्ट है
ResultSet.CONCUR_UPDATABLE एक अद्यतन करने योग्य परिणाम सेट बनाता है।

अब तक लिखे गए हमारे सभी उदाहरणों को निम्नानुसार लिखा जा सकता है, जो एक स्टेटमेंट ऑब्जेक्ट को केवल एक फॉरवर्ड-केवल बनाने के लिए आरम्भ करता है, केवल रिजल्ट स्टेटमेंट पढ़ें -

try {
   Statement stmt = conn.createStatement(
                           ResultSet.TYPE_FORWARD_ONLY,
                           ResultSet.CONCUR_READ_ONLY);
}
catch(Exception ex) {
   ....
}
finally {
   ....
}

रिजल्ट सेट को नेविगेट करना

ResultSet इंटरफ़ेस में कई तरीके हैं जिसमें कर्सर को शामिल करना शामिल है, जिसमें शामिल हैं -

एस.एन. तरीके और विवरण
1 public void beforeFirst() throws SQLException

पहली पंक्ति के ठीक पहले कर्सर ले जाता है।

2 public void afterLast() throws SQLException

अंतिम पंक्ति के ठीक बाद कर्सर ले जाता है।

3 public boolean first() throws SQLException

कर्सर को पहली पंक्ति में ले जाता है।

4 public void last() throws SQLException

कर्सर को अंतिम पंक्ति में ले जाता है।

5 public boolean absolute(int row) throws SQLException

कर्सर को निर्दिष्ट पंक्ति में ले जाता है।

6 public boolean relative(int row) throws SQLException

कर्सर को आगे या पीछे की पंक्तियों की संख्या को ले जाता है, जहाँ से वह वर्तमान में इंगित कर रहा है।

7 public boolean previous() throws SQLException

कर्सर को पिछली पंक्ति में ले जाता है। यदि पिछली पंक्ति परिणाम सेट बंद है तो यह विधि गलत है।

8 public boolean next() throws SQLException

कर्सर को अगली पंक्ति में ले जाता है। यदि परिणाम सेट में कोई और पंक्तियाँ नहीं हैं, तो यह विधि गलत है।

9 public int getRow() throws SQLException

कर्सर को इंगित करने वाली पंक्ति संख्या लौटाता है।

10 public void moveToInsertRow() throws SQLException

परिणाम सेट में कर्सर को एक विशेष पंक्ति में ले जाता है जिसका उपयोग डेटाबेस में एक नई पंक्ति सम्मिलित करने के लिए किया जा सकता है। वर्तमान कर्सर स्थान को याद किया जाता है।

1 1 public void moveToCurrentRow() throws SQLException

यदि कर्सर वर्तमान में सम्मिलित पंक्ति में है, तो कर्सर को वर्तमान पंक्ति में वापस ले जाता है; अन्यथा, यह विधि कुछ भी नहीं करती है

एक बेहतर समझ के लिए, हम नेविगेट - उदाहरण कोड का अध्ययन करते हैं ।

परिणाम सेट देखना

ResultSet इंटरफ़ेस में वर्तमान पंक्ति का डेटा प्राप्त करने के दर्जनों तरीके हैं।

प्रत्येक संभव डेटा प्रकारों के लिए एक विधि है, और प्रत्येक प्राप्त विधि के दो संस्करण हैं -

  • एक जो कॉलम नाम में लेता है।

  • एक जो एक कॉलम इंडेक्स में लेता है।

उदाहरण के लिए, यदि आप जिस कॉलम को देखने में रुचि रखते हैं, उसमें एक इंट शामिल है, तो आपको रिजल्टसेट के getInt () तरीकों में से एक का उपयोग करने की आवश्यकता है -

एस.एन. तरीके और विवरण
1 public int getInt(String columnName) throws SQLException

कॉलम नाम वाले कॉलम में वर्तमान पंक्ति में int लौटाता है।

2 public int getInt(int columnIndex) throws SQLException

निर्दिष्ट कॉलम इंडेक्स में वर्तमान पंक्ति में int लौटाता है। कॉलम इंडेक्स 1 से शुरू होता है, जिसका अर्थ है कि एक पंक्ति का पहला कॉलम 1 है, एक पंक्ति का दूसरा कॉलम 2 है, और इसी तरह।

इसी तरह, आठ जावा आदिम प्रकारों में से प्रत्येक के लिए रिजल्टसेट इंटरफ़ेस में विधियां प्राप्त होती हैं, साथ ही सामान्य प्रकार जैसे कि java.lang.String, java.lang.Object और java.net.URL।

SQL डेटा प्रकार java.sql.Date, java.sql.Time, java.sql.TimeStamp, java.sql.Clob, और java.sql.Blob प्राप्त करने की विधियाँ भी हैं। इन SQL डेटा प्रकारों का उपयोग करने के बारे में अधिक जानकारी के लिए दस्तावेज़ की जाँच करें।

एक बेहतर समझ के लिए, हमें देखने के उदाहरण - उदाहरण कोड का अध्ययन करना चाहिए ।

रिजल्ट सेट को अपडेट करना

परिणाम सेट के डेटा को अपडेट करने के लिए ResultSet इंटरफ़ेस में अपडेट विधियों का एक संग्रह है।

प्राप्त तरीकों के साथ, प्रत्येक डेटा प्रकार के लिए दो अद्यतन विधियाँ हैं -

  • एक जो कॉलम नाम में लेता है।

  • एक जो एक कॉलम इंडेक्स में लेता है।

उदाहरण के लिए, किसी परिणाम सेट की वर्तमान पंक्ति के स्ट्रिंग कॉलम को अपडेट करने के लिए, आप निम्न अपडेट में से एक का उपयोग करेंगे।

एस.एन. तरीके और विवरण
1 public void updateString(int columnIndex, String s) throws SQLException

स्ट्रिंग को एस के मान में निर्दिष्ट कॉलम में बदलता है।

2 public void updateString(String columnName, String s) throws SQLException

पिछली पद्धति के समान, सिवाय इसके कि स्तंभ को उसके सूचकांक के बजाय उसके नाम द्वारा निर्दिष्ट किया गया है।

Java.sql पैकेज में आठ आदिम डेटा प्रकारों के साथ-साथ स्ट्रिंग, ऑब्जेक्ट, URL और SQL डेटा प्रकारों के लिए अद्यतन विधियाँ हैं।

परिणाम सेट में एक पंक्ति को अपडेट करने से ResultSet ऑब्जेक्ट में वर्तमान पंक्ति के कॉलम बदल जाते हैं, लेकिन अंतर्निहित डेटाबेस में नहीं। डेटाबेस में पंक्ति में अपने परिवर्तनों को अपडेट करने के लिए, आपको निम्न विधियों में से एक को लागू करना होगा।

एस.एन. तरीके और विवरण
1 public void updateRow()

डेटाबेस में संबंधित पंक्ति को अपडेट करके वर्तमान पंक्ति को अपडेट करता है।

2 public void deleteRow()

डेटाबेस से वर्तमान पंक्ति हटाता है

3 public void refreshRow()

डेटाबेस में किसी भी हाल के परिवर्तनों को प्रतिबिंबित करने के लिए सेट किए गए परिणाम में डेटा को ताज़ा करता है।

4 public void cancelRowUpdates()

वर्तमान पंक्ति पर किए गए किसी भी अद्यतन को रद्द कर देता है।

5 public void insertRow()

डेटाबेस में एक पंक्ति सम्मिलित करता है। यह विधि केवल तब लागू की जा सकती है जब कर्सर सम्मिलित पंक्ति की ओर इशारा कर रहा हो।

एक बेहतर समझ के लिए, आइए हम अपडेटिंग - उदाहरण कोड का अध्ययन करें ।