अपाचे डर्बी - डेटा पुनर्प्राप्त

SELECT स्टेटमेंट का उपयोग टेबल से डेटा पुनः प्राप्त करने के लिए किया जाता है। यह परिणाम सेट के रूप में ज्ञात तालिका के रूप में डेटा लौटाता है।

वाक्य - विन्यास

निम्नलिखित सिलेक्ट स्टेटमेंट का सिंटैक्स है -

ij> SELECT column_name, column_name, ... FROM table_name;
Or,
Ij>SELECT * from table_name

उदाहरण

मान लें कि हमारे पास डेटाबेस में कर्मचारी नाम की एक तालिका है जैसा कि नीचे दिखाया गया है -

ij> CREATE TABLE Employees (
   Id INT NOT NULL GENERATED ALWAYS AS IDENTITY,
   Name VARCHAR(255),
   Salary INT NOT NULL,
   Location VARCHAR(255),
   PRIMARY KEY (Id)
);
> > > > > > > 0 rows inserted/updated/deleted

और, नीचे दिखाए गए अनुसार चार रिकॉर्ड डाले -

ij> INSERT INTO Employees (Name, Salary, Location) VALUES
 ('Amit', 30000, 'Hyderabad'),
 ('Kalyan', 40000, 'Vishakhapatnam'),
 ('Renuka', 50000, 'Delhi'),
 ('Archana', 15000, 'Mumbai');
> > > > 4 rows inserted/updated/deleted

निम्न SQL कथन तालिका में सभी कर्मचारियों के नाम, आयु और वेतन विवरण को पुनः प्राप्त करता है;

ij> SELECT Id, Name, Salary FROM Employees;

इस क्वेरी का आउटपुट है -

ID |NAME |SALARY
------------------------------------------------------------------------
1 |Amit |30000
2 |Kalyan |40000
3 |Renuka |50000
4 |Archana |15000
4 rows selected

यदि आप एक ही बार में इस तालिका के सभी रिकॉर्ड प्राप्त करना चाहते हैं, तो कॉलम के नामों के बजाय * का उपयोग करें।

ij> select * from Employees;

यह निम्नलिखित परिणाम का उत्पादन करेगा -

ID |NAME |SALARY |LOCATION
------------------------------------------------------------------
1 |Amit |30000 |Hyderabad
2 |Kalyan |40000 |Vishakhapatnam
3 |Renuka |50000 |Delhi
4 |Archana |15000 |Mumbai
4 rows selected

JDBC प्रोग्राम का उपयोग करके डेटा पुनः प्राप्त करें

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

यदि आप नेटवर्क क्लाइंट का उपयोग करके डर्बी नेटवर्क सर्वर का अनुरोध करना चाहते हैं, तो सुनिश्चित करें कि सर्वर ऊपर और चल रहा है। नेटवर्क क्लाइंट ड्राइवर का वर्ग नाम org.apache.derby.jdbc.ClientDriver है और URL jdbc: derby: // localhost: 1527 / हैDATABASE_NAME; सच बनाने =; उपयोगकर्ता =USER_NAME; पासवड ऑर्ड =PASSWORD"

अपाचे डर्बी में एक तालिका से डेटा पुनः प्राप्त करने के लिए नीचे दिए गए चरणों का पालन करें -

चरण 1: चालक को पंजीकृत करें

डेटाबेस के साथ संवाद करने के लिए, सबसे पहले, आपको चालक को पंजीकृत करने की आवश्यकता है। forName() कक्षा की विधि Classएक स्ट्रिंग मान को स्वीकार करता है जो एक वर्ग नाम का प्रतिनिधित्व करता है, इसे मेमोरी में लोड करता है, जो स्वचालित रूप से इसे पंजीकृत करता है। इस विधि का उपयोग करके चालक को पंजीकृत करें।

चरण 2: कनेक्शन प्राप्त करें

सामान्य तौर पर, हम डेटाबेस से संवाद करने के लिए पहला कदम इसके साथ जुड़ना चाहते हैं। Connectionवर्ग एक डेटाबेस सर्वर के साथ शारीरिक संबंध का प्रतिनिधित्व करता है। आप इनवॉइस करके कनेक्शन ऑब्जेक्ट बना सकते हैंgetConnection() की विधि DriverManagerकक्षा। इस विधि का उपयोग करके एक कनेक्शन बनाएँ।

चरण 3: एक स्टेटमेंट ऑब्जेक्ट बनाएं

आपको एक बनाने की आवश्यकता है Statement या PreparedStatement या, CallableStatementडेटाबेस में एसक्यूएल स्टेटमेंट भेजने के लिए ऑब्जेक्ट। आप इन विधियों का उपयोग करके बना सकते हैंcreateStatement(), prepareStatement() तथा, prepareCall()क्रमशः। उपयुक्त विधि का उपयोग करके इन दोनों वस्तुओं को बनाएं।

चरण 4: क्वेरी निष्पादित करें

एक बयान बनाने के बाद, आपको इसे निष्पादित करने की आवश्यकता है। Statement वर्ग एक क्वेरी को निष्पादित करने के लिए विभिन्न तरीके प्रदान करता है execute()एक कथन को निष्पादित करने की विधि जो एक से अधिक परिणाम सेट लौटाती है। executeUpdate()विधि INSERT, UPDATE, DELETE जैसे प्रश्नों का निष्पादन करती है। executeQuery() परिणामों के लिए विधि जो डेटा लौटाती है आदि इन विधियों में से किसी का उपयोग करें और पहले बनाए गए कथन को निष्पादित करें।

उदाहरण

JDBC उदाहरण के बाद दर्शाता है कि JDBC प्रोग्राम का उपयोग करके अपाचे डर्बी में एक तालिका से डेटा को कैसे प्राप्त किया जाए। यहां, हम एम्बेडेड ड्राइवर का उपयोग करके नमूनाडीबी नामक एक डेटाबेस से कनेक्ट कर रहे हैं (यदि यह मौजूद नहीं है तो बना देगा)।

executeQuery() विधि एक रिटर्न ResultSetवस्तु जो कथन का परिणाम रखती है। प्रारंभ में परिणाम सेट पॉइंटर पहले रिकॉर्ड पर होगा, आप इसका उपयोग करके रिजल्टसेट ऑब्जेक्ट की सामग्री को प्रिंट कर सकते हैंnext() तथा getXXX() तरीकों।

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class RetrieveData {
   public static void main(String args[]) throws SQLException,
      ClassNotFoundException {
      //Registering the driver
      Class.forName("org.apache.derby.jdbc.EmbeddedDriver");
      //Getting the Connection object
      String URL = "jdbc:derby:sampleDB;create=true";
      Connection conn = DriverManager.getConnection(URL);

      //Creating the Statement object
      4Statement stmt = conn.createStatement();

      //Creating a table and populating it
      String query = "CREATE TABLE Employees("
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "PRIMARY KEY (Id))";
      String query = "INSERT INTO Employees("
         + "Name, Salary, Location) VALUES "
         + "('Amit', 30000, 'Hyderabad'), "
         + "('Kalyan', 40000, 'Vishakhapatnam'), "
         + "('Renuka', 50000, 'Delhi'), "
         + "('Archana', 15000, 'Mumbai'), "
         + "('Trupthi', 45000, 'Kochin'), "
         + "('Suchatra', 33000, 'Pune'), "
         + "('Rahul', 39000, 'Lucknow'), "
         + "('Trupti', 45000, 'Kochin')";
      //Executing the query
      String query = "SELECT Id, Name, Salary FROM Employees";
      ResultSet rs = stmt.executeQuery(query);
      while(rs.next()) {
         System.out.println("Id: "+rs.getString("Id"));
         System.out.println("Name: "+rs.getString("Name"));
         System.out.println("Salary: "+rs.getString("Salary"));
         System.out.println(" ");
      }
   }
}

उत्पादन

उपरोक्त कार्यक्रम को निष्पादित करने पर, आपको निम्न आउटपुट मिलेगा

Id: 1
Name: Amit
Salary: 30000

Id: 2
Name: Kalyan
Salary: 43000

Id: 3
Name: Renuka
Salary: 50000

Id: 4
Name: Archana
Salary: 15000

Id: 5
Name: Trupthi
Salary: 45000

Id: 6
Name: Suchatra
Salary: 33000

Id: 7
Name: Rahul
Salary: 39000