अपाचे डर्बी - जहां क्लॉज

जहां खंड का चयन उन पंक्तियों को निर्दिष्ट करने के लिए सेलेक्ट, DELETE या UPDATE स्टेटमेंट में किया जाता है, जिन पर ऑपरेशन किए जाने की आवश्यकता होती है। आमतौर पर, यह क्लॉज एक शर्त या अभिव्यक्ति के बाद होता है जो बूलियन मान लौटाता है, चयन, हटाएं या अपडेट करें कार्रवाई केवल उन पंक्तियों पर की जाती है जो दी गई स्थिति को पूरा करती हैं।

ij> SELECT * from table_name WHERE condition;
or,
ij> DELETE from table_name WHERE condition;
or,
ij> UPDATE table_name SET column_name = value WHERE condition;

WHERE क्लॉज तुलना संचालकों जैसे =; =!, <,>, <=, और> =, साथ ही साथ बीटा और लाईक ऑपरेटरों का उपयोग कर सकता है।

उदाहरण

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

ID |NAME |SALARY |LOCATION
-----------------------------------------------------------------------------
1 |Amit |30000 |Hyderabad
2 |Kalyan |40000 |Vishakhapatnam
3 |Renuka |50000 |Delhi
4 |Archana |15000 |Mumbai
5 |Trupthi |45000 |Kochin
6 |Suchatra |33000 |Pune
7 |Rahul |39000 |Lucknow

निम्नलिखित एसक्यूएल DELETE स्टेटमेंट में उन कर्मचारियों के रिकॉर्ड शामिल हैं, जिनका वेतन 35000 से अधिक है -

ij> SELECT * FROM Employees WHERE Salary>35000;

इससे निम्नलिखित उत्पादन होगा -

ID |NAME |SALARY |LOCATION 
---------------------------------------------------
2 |Kalyan |40000 |Vishakhapatnam
3 |Renuka |50000 |Delhi
5 |Trupthi |45000 |Kochin
7 |Rahul |39000 |Lucknow
4 rows selected

इसी तरह, आप इस क्लॉज का उपयोग करके रिकॉर्ड को हटा और अपडेट भी कर सकते हैं।

उदाहरण के बाद उन लोगों के स्थान को अद्यतन करता है जिनका वेतन 30000 से कम है।

ij> UPDATE Employees SET Location = 'Vijayawada' WHERE Salary<35000;
3 rows inserted/updated/deleted

यदि आप तालिका की सामग्री को सत्यापित करते हैं, तो आप अद्यतन तालिका को नीचे दिखाए अनुसार देख सकते हैं -

ij> SELECT * FROM Employees;
ID |NAME |SALARY |LOCATION
------------------------------------------------------------------------------
1 |Amit |30000 |Vijayawada
2 |Kalyan |40000 |Vishakhapatnam
3 |Renuka |50000 |Delhi
4 |Archana |15000 |Vijayawada
5 |Trupthi |45000 |Kochin
6 |Suchatra |33000 |Vijayawada
7 |Rahul |39000 |Lucknow
7 rows selected

जहां क्लॉज जेडीबीसी उदाहरण है

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

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

WHERE क्लॉज का उपयोग करने के लिए नीचे दिए गए चरणों का पालन करें और Apache Derby में एक टेबल पर CURD संचालन करें

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

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

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

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

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

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

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

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

उदाहरण

JDBC के उदाहरण के बाद दर्शाता है कि WHERE क्लॉज़ का उपयोग कैसे किया जाता है और JDBC प्रोग्राम का उपयोग करते हुए Apache Derby में एक टेबल पर CURD ऑपरेशन किया जाता है। यहां, हम एम्बेडेड ड्राइवर का उपयोग करके नमूनाडीबी नामक एक डेटाबेस से कनेक्ट कर रहे हैं (यदि यह मौजूद नहीं है तो बना देगा)।

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.sql.ResultSet;
public class WhereClauseExample {
   public static void main(String args[]) throws Exception {
      //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
      Statement 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 * FROM Employees WHERE Salary>35000";
      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("Location: "+rs.getString("Location"));
         System.out.println(" ");
      }
   }
}

उत्पादन

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

Id: 2
Name: Kalyan
Salary: 43000
Location: Chennai

Id: 3
Name: Renuka
Salary: 50000
Location: Delhi

Id: 5
Name: Trupthi
Salary: 45000
Location: Kochin

Id: 7
Name: Rahul
Salary: 39000
Location: Lucknow