अपाचे डर्बी - डर्बी इंडेक्स

एक तालिका में एक सूचकांक इसके डेटा के लिए एक संकेतक के अलावा कुछ भी नहीं है। इनका उपयोग किसी तालिका से डेटा पुनर्प्राप्ति को गति देने के लिए किया जाता है।

यदि हम इंडेक्स का उपयोग करते हैं, तो INSERT और UPDATE स्टेटमेंट एक धीमी चरण में निष्पादित हो जाते हैं। जबकि SELECT और WHERE को कम समय में निष्पादित किया जाता है।

एक सूचकांक बनाना

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

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

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

CTREATE INDEX index_name on table_name (column_name);

उदाहरण

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

CREATE TABLE Emp ( Id INT NOT NULL GENERATED ALWAYS AS IDENTITY,
   Name VARCHAR(255),
   Salary INT NOT NULL,
   Location VARCHAR(255),
   Phone_Number BIGINT
);

निम्न SQL कथन तालिका कर्मचारियों में वेतन नाम के कॉलम पर एक इंडेक्स बनाता है।

ij> CREATE INDEX example_index on Emp (Salary);
0 rows inserted/updated/deleted

एक अद्वितीय सूचकांक बनाना

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

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

निम्नलिखित एक अद्वितीय सूचकांक बनाने का सिंटैक्स है।

CREATE UNIQUE INDEX index_name on table_name (column_name);

उदाहरण

निम्न उदाहरण तालिका कर्मचारी के स्तंभ क्रमांक पर एक अद्वितीय सूचकांक बनाता है।

ij> CREATE UNIQUE INDEX unique_index on Emp (Phone_Number);
0 rows inserted/updated/deleted

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

नीचे दिखाए अनुसार Emp तालिका में एक पंक्ति डालें

ij> INSERT INTO Emp(Name, Salary, Location, Phone_Number) VALUES ('Amit',
45000, 'Hyderabad', 9848022338);
1 row inserted/updated/deleted

चूंकि हमने कॉलम Phone_No पर एक अद्वितीय सूचकांक बनाया है, यदि आप पिछले रिकॉर्ड के समान मान दर्ज करते हैं, तो यह एक त्रुटि दिखाता है।

ij> INSERT INTO Emp(Name, Salary, Location, Phone_Number) VALUES ('Sumit',
35000, 'Chennai', 9848022338);
ERROR 23505: The statement was aborted because it would have caused a duplicate
key value in a unique or primary key constraint or unique index identified by
'UNIQUE_INDEX' defined on 'EMP'.

एक कम्पोजिट सूचकांक बनाना

आप दो पंक्तियों पर एक एकल सूचकांक बना सकते हैं और इसे समग्र सूचकांक कहा जाता है।

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

निम्नलिखित सम्मिश्र सूचकांक का वाक्य विन्यास है।

CREATE INDEX index_name on table_name (column_name1, column_name2);

उदाहरण

निम्नलिखित सूचकांक कॉलम नाम और स्थान पर एक समग्र सूचकांक बनाता है।

ij> CREATE INDEX composite_index on Emp (Name, Location);
0 rows inserted/updated/deleted

अनुक्रमणिका प्रदर्शित करना

SHOW INDEXES क्वेरी एक टेबल पर इंडेक्स की सूची प्रदर्शित करती है।

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

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

SHOW INDEXES FROM table_name;

उदाहरण

उदाहरण के बाद, मैं टेबल कर्मचारियों पर अनुक्रमित प्रदर्शित करता है।

ij> SHOW INDEXES FROM Emp;

यह निम्न परिणाम उत्पन्न करता है।

ij> SHOW INDEXES FROM Emp;
TABLE_NAME |COLUMN_NAME |NON_U&|TYPE|ASC&|CARDINA&|PAGES
----------------------------------------------------------------------------
EMP |PHONE_NUMBER |false |3 |A |NULL |NULL
EMP |NAME |true |3 |A |NULL |NULL
EMP |LOCATION |true |3 |A |NULL |NULL
EMP |SALARY |true |3 |A |NULL |NULL
4 rows selected

गिरते हुए सूचकांक

ड्रॉप इंडेक्स स्टेटमेंट किसी कॉलम पर दिए गए इंडेक्स को डिलीट / ड्रॉप करता है।

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

निम्नलिखित DROP INDEX स्टेटमेंट का सिंटैक्स है।

DROP INDEX index_name;

उदाहरण

उदाहरण के बाद, सम्मिश्र_index और unique_index नाम का एक इंडेक्स बनता है।

ij> DROP INDEX composite_index;
0 rows inserted/updated/deleted
ij>Drop INDEX unique_index;
0 rows inserted/updated/deleted

अब, यदि आप अनुक्रमणिकाओं की सूची को सत्यापित करते हैं, तो आप एक स्तंभ पर सूचकांक देख सकते हैं क्योंकि हमने शेष को हटा दिया है।

ij> SHOW INDEXES FROM Emp;
TABLE_NAME |COLUMN_NAME |NON_U&|TYPE|ASC&|CARDINA&|PAGES
----------------------------------------------------------------------------
EMP |SALARY |true |3 |A |NULL |NULL
1 row selected

JDBC प्रोग्राम का उपयोग कर इंडेक्स को संभालना

JDBC कार्यक्रम के बाद एक तालिका में एक स्तंभ पर ड्रॉप इंडेक्स बनाने का तरीका प्रदर्शित करता है।

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class IndexesExample {
   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:MYDATABASE;create=true";
      Connection conn = DriverManager.getConnection(URL);

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

      //Creating the Emp table
      String createQuery = "CREATE TABLE Emp( "
         + "Id INT NOT NULL GENERATED ALWAYS AS IDENTITY, "
         + "Name VARCHAR(255), "
         + "Salary INT NOT NULL, "
         + "Location VARCHAR(255), "
         + "Phone_Number BIGINT )";
      stmt.execute(createQuery);
      System.out.println("Table created");
      System.out.println(" ");

      //Creating an Index on the column Salary
      stmt.execute("CREATE INDEX example_index on Emp (Salary)");
      System.out.println("Index example_index inserted");
      System.out.println(" ");

      //Creating an Unique index on the column Phone_Number
      stmt.execute("CREATE UNIQUE INDEX unique_index on Emp (Phone_Number)");
      System.out.println("Index unique_index inserted");
      System.out.println(" ");

      //Creating a Composite Index on the columns Name and Location
      stmt.execute("CREATE INDEX composite_index on Emp (Name, Location)");
      System.out.println("Index composite_index inserted");
      System.out.println(" ");

      //listing all the indexes
      System.out.println("Listing all the columns with indexes");

      //Dropping indexes
      System.out.println("Dropping indexes unique_index and, composite_index ");
      stmt.execute("Drop INDEX unique_index");
      stmt.execute("DROP INDEX composite_index");
   }
}

उत्पादन

निष्पादित करने पर, यह निम्नलिखित परिणाम उत्पन्न करता है

Table created
Index example_index inserted

Index unique_index inserted

Index composite_index inserted

Listing all the columns with indexes
Dropping indexes unique_index and, composite_index