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