MySQL(151)什么是MySQL的二级索引?

MySQL 中的二级索引(Secondary Index),也称为非聚簇索引,是一种用于加速数据检索的索引,但它并不像聚簇索引(Primary Index)那样将数据存储在索引结构中。二级索引存储的是索引列的值和主键的值,通过主键值可以进一步访问表中的完整记录。

一、二级索引的工作原理

二级索引包含以下内容:

  1. 索引列的值:用于进行快速查找。
  2. 主键的值:用于通过主键定位到表中实际的数据行。

当使用二级索引进行查询时,MySQL会通过索引列的值找到对应的主键,然后再通过主键去查找实际的数据行。

二、创建和使用二级索引

以下是一个创建和使用二级索引的详细示例,包括创建表、插入数据、创建索引以及执行查询。

1. 创建数据库和表

首先,创建一个数据库和一个示例表。

sql 复制代码
CREATE DATABASE example_db;
USE example_db;

CREATE TABLE employees (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    department VARCHAR(100),
    salary DECIMAL(10, 2)
);

2. 插入示例数据

插入一些示例数据。

sql 复制代码
INSERT INTO employees (name, department, salary) VALUES
('Alice', 'Engineering', 70000),
('Bob', 'Marketing', 50000),
('Charlie', 'Engineering', 80000),
('David', 'HR', 60000),
('Eve', 'Marketing', 55000);

3. 创建二级索引

department列上创建一个二级索引。

sql 复制代码
CREATE INDEX idx_department ON employees(department);

4. 使用二级索引进行查询

使用二级索引进行查询,通过EXPLAIN命令可以看到索引的使用情况。

sql 复制代码
EXPLAIN SELECT * FROM employees WHERE department = 'Engineering';

查询结果将显示MySQL使用了idx_department索引。

三、代码示例

以下是一个使用Java和JDBC来操作MySQL二级索引的示例。

1. 创建表和插入数据

java 复制代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

public class MySQLSetup {

    private static final String URL = "jdbc:mysql://localhost:3306/example_db";
    private static final String USER = "root";
    private static final String PASSWORD = "password";

    public static void main(String[] args) {
        try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);
             Statement stmt = conn.createStatement()) {

            String createTable = "CREATE TABLE IF NOT EXISTS employees ("
                    + "id INT AUTO_INCREMENT PRIMARY KEY, "
                    + "name VARCHAR(100), "
                    + "department VARCHAR(100), "
                    + "salary DECIMAL(10, 2)"
                    + ")";
            stmt.execute(createTable);

            String insertData = "INSERT INTO employees (name, department, salary) VALUES "
                    + "('Alice', 'Engineering', 70000), "
                    + "('Bob', 'Marketing', 50000), "
                    + "('Charlie', 'Engineering', 80000), "
                    + "('David', 'HR', 60000), "
                    + "('Eve', 'Marketing', 55000)";
            stmt.execute(insertData);

            String createIndex = "CREATE INDEX idx_department ON employees(department)";
            stmt.execute(createIndex);

            System.out.println("Table, data, and index created successfully.");

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

2. 使用索引进行查询

java 复制代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

public class MySQLQuery {

    private static final String URL = "jdbc:mysql://localhost:3306/example_db";
    private static final String USER = "root";
    private static final String PASSWORD = "password";

    public static void main(String[] args) {
        try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD)) {
            String query = "SELECT * FROM employees WHERE department = ?";
            try (PreparedStatement pstmt = conn.prepareStatement(query)) {
                pstmt.setString(1, "Engineering");

                try (ResultSet rs = pstmt.executeQuery()) {
                    while (rs.next()) {
                        int id = rs.getInt("id");
                        String name = rs.getString("name");
                        String department = rs.getString("department");
                        double salary = rs.getDouble("salary");
                        System.out.printf("ID: %d, Name: %s, Department: %s, Salary: %.2f%n", id, name, department, salary);
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

四、总结

二级索引是一个非常有效的工具,当查询的条件是非主键列时,通过二级索引可以大大加速数据检索。通过上述示例,可以看到如何在MySQL中创建和使用二级索引,以及如何使用Java代码来操作和查询带有二级索引的表。

相关推荐
MadPrinter26 分钟前
SpringBoot学习日记 Day11:博客系统核心功能深度开发
java·spring boot·后端·学习·spring·mybatis
dasseinzumtode26 分钟前
nestJS 使用ExcelJS 实现数据的excel导出功能
前端·后端·node.js
淦出一番成就29 分钟前
Java反序列化接收多种格式日期-JsonDeserialize
java·后端
Java中文社群31 分钟前
Hutool被卖半年多了,现状是逆袭还是沉寂?
java·后端
程序员蜗牛1 小时前
9个Spring Boot参数验证高阶技巧,第8,9个代码量直接减半!
后端
yeyong1 小时前
咨询kimi关于设计日志告警功能,还是有启发的
后端
库森学长1 小时前
2025年,你不能错过Spring AI,那个汲取了LangChain灵感的家伙!
后端·openai·ai编程
Java水解2 小时前
Spring Boot 启动流程详解
spring boot·后端
学历真的很重要2 小时前
Claude Code Windows 原生版安装指南
人工智能·windows·后端·语言模型·面试·go
转转技术团队2 小时前
让AI成为你的编程助手:如何高效使用Cursor
后端·cursor