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

HAVING क्लॉज आपको उन स्थितियों को निर्दिष्ट करने में सक्षम करता है जो फ़िल्टर करते हैं कि परिणाम में कौन से समूह परिणाम दिखाई देते हैं।

WHERE क्लॉज चयनित कॉलम पर स्थितियां रखता है, जबकि HAVING क्लॉज GROUP BY क्लॉज द्वारा बनाए गए समूहों पर स्थितियां रखता है।

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

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

ij> SELECT column1, column2 . . . from table_name GROUP BY column having
condition;

उदाहरण

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

ID |NAME |SALARY |LOCATION
------------------------------------------------------------------
1 |Amit |30000 |Hyderabad
2 |Rahul |39000 |Lucknow
3 |Kalyan |40000 |Vishakhapatnam
4 |Renuka |50000 |Hyderabad
5 |Archana |15000 |Vishakhapatnam
6 |Krishna |40000 |Hyderabad
7 |Trupthi |45000 |Vishakhapatnam
8 |Raghav |12000 |Lucknow
9 |Radha |50000 |Delhi
10 |Anirudh |15000 |Mumbai
11 |Tara |45000 |Kochin
12 |Sucharita |44000 |Kochin
13 |Rizwan |20000 |Lucknow

निम्नलिखित क्वेरी उस स्थान के कर्मचारियों के अधिकतम वेतन को प्रदर्शित करती है जिसमें कम से कम 3 कर्मचारी हैं -

ij> SELECT Location, MAX(Salary) from Employees GROUP BY Location having
count(Location)>=3;

यह निम्न आउटपुट उत्पन्न करता है -

LOCATION |2
------------------------------------------------------------
Hyderabad |50000
Lucknow |39000
Vishakhapatnam |45000
3 rows selected

JDBC प्रोग्राम का उपयोग करके डेटा को क्रमबद्ध करना

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

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

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

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

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

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

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

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

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

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

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

उदाहरण

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

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.sql.ResultSet;
public class HavingClauseExample {
   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
      stmt.execute("CREATE TABLE EmployeesData( "
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), "
         + "Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "PRIMARY KEY (Id))");
      stmt.execute("INSERT INTO EmployeesData(Name, Salary, Location) "
         + "VALUES ('Amit', 30000, 'Hyderabad'), "
         + "('Rahul', 39000, 'Lucknow'), "
         + "('Renuka', 50000, 'Hyderabad'), "
         + "('Archana', 15000, 'Vishakhapatnam'), "
         + "('Kalyan', 40000, 'Hyderabad'), "
         + "('Trupthi', 45000, 'Vishakhapatnam'), "
         + "('Raghav', 12000, 'Lucknow'), "
         + "('Suchatra', 33000, 'Vishakhapatnam'), "
         + "('Rizwan', 20000, 'Lucknow')");
      //Executing the query
      String query = "SELECT Location, MAX(Salary) "
         + "from EmployeesData GROUP BY Location having "
         + "count(Location)>=3";
      ResultSet rs = stmt.executeQuery(query);
      while(rs.next()) {
         System.out.println(rs.getString(1));
         System.out.println(rs.getString(2));
         System.out.println(" ");
      }
   }
}

उत्पादन

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

Hyderabad
50000

Lucknow
39000

Vishakhapatnam
45000