सर्वलेट्स - डेटाबेस एक्सेस

यह ट्यूटोरियल मानता है कि JDBC एप्लिकेशन कैसे काम करता है, इस पर आपकी समझ है। सर्वलेट के माध्यम से डेटाबेस एक्सेस के साथ शुरू करने से पहले, सुनिश्चित करें कि आपके पास डेटाबेस के साथ उचित JDBC पर्यावरण सेटअप है।

JDBC और इसके पर्यावरण सेटअप का उपयोग करके डेटाबेस तक पहुँचने के तरीके के बारे में अधिक विस्तार के लिए आप हमारे JDBC ट्यूटोरियल के माध्यम से जा सकते हैं ।

बुनियादी अवधारणा से शुरू करने के लिए, आइए हम एक सरल तालिका बनाते हैं और उस तालिका में कुछ रिकॉर्ड बनाते हैं -

तालिका बनाएं

बनाने के लिए Employees तालिका डेटाबेस में, निम्न चरणों का उपयोग करें -

चरण 1

एक खोलो Command Prompt और स्थापना निर्देशिका में परिवर्तन इस प्रकार है -

C:\>
C:\>cd Program Files\MySQL\bin
C:\Program Files\MySQL\bin>

चरण 2

डेटाबेस में निम्नानुसार लॉगिन करें

C:\Program Files\MySQL\bin>mysql -u root -p
Enter password: ********
mysql>

चरण 3

तालिका बनाएं Employee में TEST डेटाबेस इस प्रकार है -

mysql> use TEST;
mysql> create table Employees (
   id int not null,
   age int not null,
   first varchar (255),
   last varchar (255)
);
Query OK, 0 rows affected (0.08 sec)
mysql>

डेटा रिकॉर्ड बनाएँ

अंत में आप कर्मचारी तालिका में कुछ रिकॉर्ड बनाते हैं -

mysql> INSERT INTO Employees VALUES (100, 18, 'Zara', 'Ali');
Query OK, 1 row affected (0.05 sec)
 
mysql> INSERT INTO Employees VALUES (101, 25, 'Mahnaz', 'Fatma');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (102, 30, 'Zaid', 'Khan');
Query OK, 1 row affected (0.00 sec)
 
mysql> INSERT INTO Employees VALUES (103, 28, 'Sumit', 'Mittal');
Query OK, 1 row affected (0.00 sec)
 
mysql>

एक डेटाबेस तक पहुँचने

यहाँ एक उदाहरण है जो दिखाता है कि कैसे सर्वलेट का उपयोग करके TEST डेटाबेस तक पहुँचना है।

// Loading required libraries
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.*;
 
public class DatabaseAccess extends HttpServlet{

   public void doGet(HttpServletRequest request, HttpServletResponse response)
      throws ServletException, IOException {
   
      // JDBC driver name and database URL
      static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
      static final String DB_URL="jdbc:mysql://localhost/TEST";

      //  Database credentials
      static final String USER = "root";
      static final String PASS = "password";

      // Set response content type
      response.setContentType("text/html");
      PrintWriter out = response.getWriter();
      String title = "Database Result";
      
      String docType =
         "<!doctype html public \"-//w3c//dtd html 4.0 " + "transitional//en\">\n";
      
      out.println(docType +
         "<html>\n" +
         "<head><title>" + title + "</title></head>\n" +
         "<body bgcolor = \"#f0f0f0\">\n" +
         "<h1 align = \"center\">" + title + "</h1>\n");
      try {
         // Register JDBC driver
         Class.forName("com.mysql.jdbc.Driver");

         // Open a connection
         Connection conn = DriverManager.getConnection(DB_URL, USER, PASS);

         // Execute SQL query
         Statement stmt = conn.createStatement();
         String sql;
         sql = "SELECT id, first, last, age FROM Employees";
         ResultSet rs = stmt.executeQuery(sql);

         // Extract data from result set
         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
            out.println("ID: " + id + "<br>");
            out.println(", Age: " + age + "<br>");
            out.println(", First: " + first + "<br>");
            out.println(", Last: " + last + "<br>");
         }
         out.println("</body></html>");

         // Clean-up environment
         rs.close();
         stmt.close();
         conn.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)
               stmt.close();
         } catch(SQLException se2) {
         } // nothing we can do
         try {
            if(conn!=null)
            conn.close();
         } catch(SQLException se) {
            se.printStackTrace();
         } //end finally try
      } //end try
   }
}

अब हमें सर्वलेट के ऊपर संकलन करें और web.xml में निम्नलिखित प्रविष्टियाँ बनाएँ

....
<servlet>
   <servlet-name>DatabaseAccess</servlet-name>
   <servlet-class>DatabaseAccess</servlet-class>
</servlet>
 
<servlet-mapping>
   <servlet-name>DatabaseAccess</servlet-name>
   <url-pattern>/DatabaseAccess</url-pattern>
</servlet-mapping>
....

अब URL http: // localhost: 8080 / DatabaseAccess का उपयोग करके इस सर्वलेट को कॉल करें, जो निम्नलिखित प्रतिक्रिया प्रदर्शित करेगा -

Database Result

ID: 100, Age: 18, First: Zara, Last: Ali ID: 101, Age: 25, First: Mahnaz, Last: Fatma ID: 102, Age: 30, First: Zaid, Last: Khan ID: 103, Age: 28, First: Sumit, Last: Mittal