जेडीबीसी - स्टेटमेंट्स, प्रिपेयरेडस्टैटेमेंट और कॉल करने योग्य स्टेटमेंट

एक बार कनेक्शन प्राप्त होने के बाद हम डेटाबेस के साथ बातचीत कर सकते हैं। JDBC स्टेटमेंट, CallableStatement, और ReadyedStatement इंटरफेस उन तरीकों और गुणों को परिभाषित करते हैं जो आपको SQL या PL / SQL कमांड भेजने और अपने डेटाबेस से डेटा प्राप्त करने में सक्षम करते हैं।

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

निम्न तालिका इंटरफ़ेस का उपयोग करने के लिए तय करने के लिए प्रत्येक इंटरफ़ेस के उद्देश्य का सारांश प्रदान करती है।

इंटरफेस अनुशंसित उपयोग
बयान अपने डेटाबेस तक सामान्य-उद्देश्य पहुंच के लिए इसका उपयोग करें। उपयोगी जब आप स्थैतिक एसक्यूएल स्टेटमेंट का उपयोग रनटाइम पर कर रहे हों। स्टेटमेंट इंटरफ़ेस मापदंडों को स्वीकार नहीं कर सकता है।
तैयार बयान जब आप कई बार SQL स्टेटमेंट का उपयोग करने की योजना बनाते हैं तो इसका उपयोग करें। रेडीस्टैटमेंट इंटरफ़ेस रनटाइम पर इनपुट मापदंडों को स्वीकार करता है।
CallableStatement जब आप डेटाबेस संग्रहीत कार्यविधियों का उपयोग करना चाहते हैं तो इसका उपयोग करें। CallableStatement इंटरफ़ेस रनटाइम इनपुट मापदंडों को भी स्वीकार कर सकता है।

बयान वस्तुओं

स्टेटमेंट ऑब्जेक्ट बनाना

किसी SQL कथन को निष्पादित करने के लिए स्टेटमेंट ऑब्जेक्ट का उपयोग करने से पहले, आपको कनेक्शन ऑब्जेक्ट के createStatement () विधि का उपयोग करके एक बनाने की आवश्यकता है, जैसा कि निम्नलिखित उदाहरण में है -

Statement stmt = null;
try {
   stmt = conn.createStatement( );
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   . . .
}

एक बार जब आप स्टेटमेंट ऑब्जेक्ट बना लेते हैं, तो आप इसका उपयोग SQL स्टेटमेंट को उसके तीन निष्पादन विधियों में से एक के साथ निष्पादित करने के लिए कर सकते हैं।

  • boolean execute (String SQL): अगर परिणामी वस्तु को पुनः प्राप्त किया जा सकता है, तो सच का एक बूलियन मान लौटाता है; अन्यथा, यह गलत है। SQL DDL स्टेटमेंट्स को निष्पादित करने के लिए या जब आपको वास्तव में डायनेमिक SQL का उपयोग करने की आवश्यकता हो, तो इस विधि का उपयोग करें।

  • int executeUpdate (String SQL): SQL कथन के निष्पादन से प्रभावित पंक्तियों की संख्या लौटाता है। SQL कथनों को निष्पादित करने के लिए इस विधि का उपयोग करें जिसके लिए आप प्रभावित पंक्तियों की संख्या प्राप्त करने की अपेक्षा करते हैं - उदाहरण के लिए, INSERT, UPDATE, या DELETE कथन।

  • ResultSet executeQuery (String SQL): एक परिणामी वस्तु लौटाता है। जब आप परिणाम का चयन करने की अपेक्षा करते हैं, तो इस पद्धति का उपयोग करें, जैसा कि आप एक चयन कथन के साथ करेंगे।

समापन कथन वस्तु

जिस तरह आप डेटाबेस संसाधनों को बचाने के लिए एक कनेक्शन ऑब्जेक्ट को बंद करते हैं, उसी कारण से आपको स्टेटमेंट ऑब्जेक्ट को भी बंद करना चाहिए।

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

Statement stmt = null;
try {
   stmt = conn.createStatement( );
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   stmt.close();
}

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

तैयार किए गए ऑब्जेक्ट्स

PreparedStatement इंटरफ़ेस वक्तव्य इंटरफ़ेस है, जो आप एक सामान्य वक्तव्य वस्तु पर लाभ के एक जोड़े के साथ कार्यक्षमता जोड़ा देता फैली हुई है।

यह कथन आपको गतिशील रूप से तर्कों की आपूर्ति करने का लचीलापन देता है।

तैयार करना वस्तु बनाना

PreparedStatement pstmt = null;
try {
   String SQL = "Update Employees SET age = ? WHERE id = ?";
   pstmt = conn.prepareStatement(SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   . . .
}

JDBC में सभी मापदंडों का प्रतिनिधित्व किया जाता है ?प्रतीक, जिसे पैरामीटर मार्कर के रूप में जाना जाता है। SQL कथन निष्पादित करने से पहले आपको हर पैरामीटर के लिए मानों की आपूर्ति करनी चाहिए।

setXXX() विधियों के मान को मानदंड से बाँधते हैं, जहाँ XXXइनपुट पैरामीटर से बांधने के लिए आप जिस जावा वैल्यू के जावा डेटा प्रकार का प्रतिनिधित्व करते हैं। यदि आप मूल्यों की आपूर्ति करना भूल जाते हैं, तो आपको एक SQLException प्राप्त होगी।

प्रत्येक पैरामीटर मार्कर को इसकी क्रमिक स्थिति से संदर्भित किया जाता है। पहला मार्कर स्थिति 1, अगली स्थिति 2 और इसके बाद का प्रतिनिधित्व करता है। यह विधि जावा सरणी सूचकांकों से भिन्न होती है, जो 0 से शुरू होती है।

के सभी Statement object'sडेटाबेस के साथ बातचीत करने के तरीके (ए) निष्पादित (), (बी) एक्जीक्यूटिक्यू (), और (सी) एग्जीक्यूटयूडेट () भी तैयार किए गए ऑब्जेक्ट के साथ काम करते हैं। हालाँकि, SQL कथन का उपयोग करने के लिए विधियों को संशोधित किया जाता है जो मापदंडों को इनपुट कर सकते हैं।

बंद करने की तैयारी की वस्तु

जिस तरह आप एक स्टेटमेंट ऑब्जेक्ट को बंद करते हैं, उसी तरह से आपको रेडीस्टेड ऑब्जेक्ट को भी बंद करना चाहिए।

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

PreparedStatement pstmt = null;
try {
   String SQL = "Update Employees SET age = ? WHERE id = ?";
   pstmt = conn.prepareStatement(SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   pstmt.close();
}

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

CallableStatement ऑब्जेक्ट्स

जिस तरह एक कनेक्शन ऑब्जेक्ट स्टेटमेंट और रेडीस्टेड ऑब्जेक्ट बनाता है, वह कॉलेबलस्टैमेंट ऑब्जेक्ट भी बनाता है, जिसका उपयोग कॉल को डेटाबेस संग्रहीत कार्यविधि के लिए निष्पादित करने के लिए किया जाएगा।

CallableStatement Object बनाना

मान लीजिए, आपको निम्नलिखित ओरेकल संग्रहित प्रक्रिया को निष्पादित करने की आवश्यकता है -

CREATE OR REPLACE PROCEDURE getEmpName 
   (EMP_ID IN NUMBER, EMP_FIRST OUT VARCHAR) AS
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END;

NOTE: ऊपर संग्रहीत प्रक्रिया ओरेकल के लिए लिखी गई है, लेकिन हम MySQL डेटाबेस के साथ काम कर रहे हैं, तो आइए, हम MySQL के लिए एक ही संग्रहीत प्रक्रिया लिखें, जैसा कि इसे EMP डेटाबेस में बनाने के लिए है -

DELIMITER $$

DROP PROCEDURE IF EXISTS `EMP`.`getEmpName` $$
CREATE PROCEDURE `EMP`.`getEmpName` 
   (IN EMP_ID INT, OUT EMP_FIRST VARCHAR(255))
BEGIN
   SELECT first INTO EMP_FIRST
   FROM Employees
   WHERE ID = EMP_ID;
END $$

DELIMITER ;

तीन प्रकार के पैरामीटर मौजूद हैं: IN, OUT, और INOUT। ReadyedStatement ऑब्जेक्ट केवल IN पैरामीटर का उपयोग करता है। CallableStatement ऑब्जेक्ट तीनों का उपयोग कर सकता है।

यहां प्रत्येक की परिभाषा दी गई है -

पैरामीटर विवरण
में एक पैरामीटर जिसका मान अज्ञात है जब SQL स्टेटमेंट बनाया जाता है। आप मानों को सेटएक्सएक्सएक्सएक्सएक्स () विधियों के साथ IN पैरामीटर में बांधते हैं।
बाहर एक पैरामीटर जिसका मान एसक्यूएल स्टेटमेंट द्वारा आपूर्ति किया जाता है। आप getXXX () विधियों के साथ पैरामीटर को मान से पुनः प्राप्त करते हैं।
अंदर बाहर एक पैरामीटर जो इनपुट और आउटपुट दोनों मान प्रदान करता है। आप सेटएक्सएक्सएक्सएक्स () विधियों के साथ चर को बांधते हैं और गेटएक्सएक्सएक्सएक्स () विधियों के साथ मूल्यों को पुनः प्राप्त करते हैं।

निम्न कोड स्निपेट दिखाता है कि कैसे नियोजित करना है Connection.prepareCall() एक पल के लिए विधि CallableStatement पूर्ववर्ती संग्रहित प्रक्रिया पर आधारित वस्तु -

CallableStatement cstmt = null;
try {
   String SQL = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   . . .
}

स्ट्रिंग चर SQL, पैरामीटर प्लेसहोल्डर्स के साथ संग्रहीत कार्यविधि का प्रतिनिधित्व करता है।

CallableStatement ऑब्जेक्ट्स का उपयोग करना बहुत अधिक है जैसा कि ReadyedStatement ऑब्जेक्ट का उपयोग करना है। आपको कथन निष्पादित करने से पहले सभी मापदंडों पर मानों को बांधना चाहिए, या आपको एक SQLException प्राप्त होगी।

यदि आपके पास पैरामीटर हैं, तो बस उन्हीं नियमों और तकनीकों का पालन करें जो कि एक रेडीस्टेडमेंट ऑब्जेक्ट पर लागू होते हैं; सेटएक्सएएनएक्सएक्स () विधि का उपयोग करें जो जावा डेटा प्रकार से मेल खाती है जो आप बाध्यकारी हैं।

जब आप OUT और INOUT मापदंडों का उपयोग करते हैं, तो आपको एक अतिरिक्त CallableStatement विधि, registerOutParameter () को नियुक्त करना होगा। RegisterOutParameter () विधि JDBC डेटा प्रकार को उस डेटा प्रकार से बांधती है, जिसमें संग्रहीत कार्यविधि वापस आने की उम्मीद है।

एक बार जब आप अपनी संग्रहीत प्रक्रिया को कॉल करते हैं, तो आप उचित गेटएक्सएक्सएक्सएक्सएक्स () विधि के साथ ओयूटी पैरामीटर से मान प्राप्त करते हैं। यह विधि SQL प्रकार के पुनः प्राप्त मान को जावा डेटा प्रकार में डालती है।

CallableStatement ऑब्जेक्ट को बंद करना

जैसे आप अन्य स्टेटमेंट ऑब्जेक्ट को बंद करते हैं, उसी कारण से आपको CallableStatement ऑब्जेक्ट को भी बंद करना चाहिए।

क्लोज () विधि के लिए एक सरल कॉल काम करेगा। यदि आप पहले कनेक्शन ऑब्जेक्ट को बंद करते हैं, तो यह CallableStatement ऑब्जेक्ट को भी बंद कर देगा। हालांकि, आपको हमेशा उचित सफाई सुनिश्चित करने के लिए CallableStatement ऑब्जेक्ट को स्पष्ट रूप से बंद करना चाहिए।

CallableStatement cstmt = null;
try {
   String SQL = "{call getEmpName (?, ?)}";
   cstmt = conn.prepareCall (SQL);
   . . .
}
catch (SQLException e) {
   . . .
}
finally {
   cstmt.close();
}

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