JDBC - जहां क्लॉज उदाहरण है

यह अध्याय JDBC एप्लिकेशन का उपयोग करके तालिका से रिकॉर्ड का चयन करने के तरीके पर एक उदाहरण प्रदान करता है। यह तालिका से रिकॉर्ड का चयन करते समय WHERE क्लॉज का उपयोग करके अतिरिक्त शर्तें जोड़ देगा। निम्नलिखित उदाहरण को निष्पादित करने से पहले, सुनिश्चित करें कि आपके पास निम्नलिखित जगह है -

  • निम्नलिखित उदाहरण को निष्पादित करने के लिए आप उपयोगकर्ता नाम और पासवर्ड को अपने वास्तविक उपयोगकर्ता नाम और पासवर्ड से बदल सकते हैं।

  • आपका MySQL या जो भी डेटाबेस आप उपयोग कर रहे हैं, वह ऊपर और चल रहा है।

आवश्यक कदम

JDBC एप्लिकेशन का उपयोग करके एक नया डेटाबेस बनाने के लिए निम्नलिखित चरणों की आवश्यकता है -

  • Import the packages:आवश्यक है कि आप डेटाबेस प्रोग्रामिंग के लिए आवश्यक JDBC कक्षाओं वाले पैकेजों को शामिल करें। सबसे अधिक बार, आयात java.sql का उपयोग करना। * पर्याप्त होगा।

  • Register the JDBC driver: इसके लिए आवश्यक है कि आप एक ड्राइवर को इनिशियलाइज़ करें ताकि आप डेटाबेस के साथ एक संचार चैनल खोल सकें।

  • Open a connection:एक कनेक्शन ऑब्जेक्ट बनाने के लिए DriverManager.getConnection () विधि का उपयोग करने की आवश्यकता होती है , जो डेटाबेस सर्वर के साथ एक भौतिक कनेक्शन का प्रतिनिधित्व करता है।

  • Execute a query:किसी तालिका से रिकॉर्ड प्राप्त करने के लिए SQL कथन को प्रस्तुत करने और प्रस्तुत करने के लिए एक प्रकार के स्टेटमेंट का उपयोग करने की आवश्यकता होती है, जो दी गई स्थिति को पूरा करती है। इस क्वेरी का उपयोग करता हैWHERE रिकॉर्ड का चयन करने के लिए खंड।

  • Clean up the environment: स्पष्ट रूप से सभी डेटाबेस संसाधनों को बंद करने की आवश्यकता है जो जेवीएम के कचरा संग्रह पर निर्भर है।

नमूना कोड

निम्न उदाहरण JDBCExample.java में कॉपी और पेस्ट करें, संकलन करें और निम्नानुसार चलाएं -

//STEP 1. Import required packages
import java.sql.*;

public class JDBCExample {
   // JDBC driver name and database URL
   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
   static final String DB_URL = "jdbc:mysql://localhost/STUDENTS";

   //  Database credentials
   static final String USER = "username";
   static final String PASS = "password";
   
   public static void main(String[] args) {
   Connection conn = null;
   Statement stmt = null;
   try{
      //STEP 2: Register JDBC driver
      Class.forName("com.mysql.jdbc.Driver");

      //STEP 3: Open a connection
      System.out.println("Connecting to a selected database...");
      conn = DriverManager.getConnection(DB_URL, USER, PASS);
      System.out.println("Connected database successfully...");
      
      //STEP 4: Execute a query
      System.out.println("Creating statement...");
      stmt = conn.createStatement();

      // Extract records without any condition.
      System.out.println("Fetching records without condition...");
      String sql = "SELECT id, first, last, age FROM Registration";
      ResultSet rs = stmt.executeQuery(sql);

      while(rs.next()){
         //Retrieve by column name
         int id  = rs.getInt("id");
         int age = rs.getInt("age");
         String first = rs.getString("first");
         String last = rs.getString("last");

         //Display values
         System.out.print("ID: " + id);
         System.out.print(", Age: " + age);
         System.out.print(", First: " + first);
         System.out.println(", Last: " + last);
      }

      // Select all records having ID equal or greater than 101
      System.out.println("Fetching records with condition...");
      sql = "SELECT id, first, last, age FROM Registration" +
                   " WHERE id >= 101 ";
      rs = stmt.executeQuery(sql);

      while(rs.next()){
         //Retrieve by column name
         int id  = rs.getInt("id");
         int age = rs.getInt("age");
         String first = rs.getString("first");
         String last = rs.getString("last");

         //Display values
         System.out.print("ID: " + id);
         System.out.print(", Age: " + age);
         System.out.print(", First: " + first);
         System.out.println(", Last: " + last);
      }
      rs.close();
   }catch(SQLException se){
      //Handle errors for JDBC
      se.printStackTrace();
   }catch(Exception e){
      //Handle errors for Class.forName
      e.printStackTrace();
   }finally{
      //finally block used to close resources
      try{
         if(stmt!=null)
            conn.close();
      }catch(SQLException se){
      }// do nothing
      try{
         if(conn!=null)
            conn.close();
      }catch(SQLException se){
         se.printStackTrace();
      }//end finally try
   }//end try
   System.out.println("Goodbye!");
}//end main
}//end JDBCExample

अब, उपरोक्त उदाहरण को संकलित करते हैं -

C:\>javac JDBCExample.java
C:\>

जब तुम दौड़ते हो JDBCExample, यह निम्नलिखित परिणाम उत्पन्न करता है -

C:\>java JDBCExample
Connecting to a selected database...
Connected database successfully...
Creating statement...
Fetching records without condition...
ID: 100, Age: 30, First: Zara, Last: Ali
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
Fetching records with condition...
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
Goodbye!
C:\>