सर्वलेट्स - डेटाबेस एक्सेस
यह ट्यूटोरियल मानता है कि 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