Apache Derby - ดัชนี Derby

ดัชนีในตารางเป็นเพียงตัวชี้ไปยังข้อมูล สิ่งเหล่านี้ใช้เพื่อเร่งความเร็วในการดึงข้อมูลจากตาราง

หากเราใช้ดัชนีคำสั่ง INSERT และ UPDATE จะดำเนินการในระยะที่ช้าลง ในขณะที่ SELECT และ WHERE ได้รับการดำเนินการในเวลาที่น้อยกว่า

การสร้างดัชนี

คำสั่ง CREATE INDEX ใช้สำหรับการสร้างดัชนีใหม่ในตารางในฐานข้อมูล Derby

ไวยากรณ์

ต่อไปนี้เป็นไวยากรณ์ของคำสั่ง CREATE INDEX -

CTREATE INDEX index_name on table_name (column_name);

ตัวอย่าง

สมมติว่าเราได้สร้างตารางชื่อพนักงานใน Apache Derby ดังภาพด้านล่าง

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

ใน Apache Derby ดัชนี UNIQUE ใช้สำหรับการรวมข้อมูล เมื่อคุณสร้างดัชนี UNIQUE บนคอลัมน์ในตารางแล้วจะไม่อนุญาตให้มีค่าที่ซ้ำกัน

ไวยากรณ์

ต่อไปนี้เป็นไวยากรณ์ของการสร้างดัชนีเฉพาะ

CREATE UNIQUE INDEX index_name on table_name (column_name);

ตัวอย่าง

ตัวอย่างต่อไปนี้สร้างดัชนี UNIQUE บนคอลัมน์ Id ของตารางพนักงาน

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'.

การสร้างดัชนี COMPOSITE

คุณสามารถสร้างดัชนีเดียวในสองแถวและเรียกว่าดัชนีคอมโพสิต

ไวยากรณ์

ต่อไปนี้เป็นไวยากรณ์ของดัชนีคอมโพสิต

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

DROP INDEX index_name;

ตัวอย่าง

ตัวอย่างต่อไปนี้ดร็อปดัชนีชื่อ composite_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