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() डेटाबेस में एक पंक्ति सम्मिलित करता है। यह विधि केवल तब लागू की जा सकती है जब कर्सर सम्मिलित पंक्ति की ओर इशारा कर रहा हो। |
एक बेहतर समझ के लिए, आइए हम अपडेटिंग - उदाहरण कोड का अध्ययन करें ।