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代码来操作和查询带有二级索引的表。

相关推荐
Tony Bai5 小时前
【Go开发者的数据库设计之道】07 诊断篇:SQL 性能诊断与问题排查
开发语言·数据库·后端·sql·golang
花花鱼6 小时前
spring boot项目使用tomcat发布,也可以使用Undertow(理论)
spring boot·后端·tomcat
你的人类朋友8 小时前
快速搭建redis环境并使用redis客户端进行连接测试
前端·redis·后端
235169 小时前
【MySQL】数据库事务深度解析:从四大特性到隔离级别的实现逻辑
java·数据库·后端·mysql·java-ee
何中应10 小时前
MyBatis-Plus字段类型处理器使用
java·数据库·后端·mybatis
绝无仅有10 小时前
资深面试题之MySQL问题及解答(二)
后端·面试·github
绝无仅有10 小时前
某大厂库存秒杀的设计与实现总结
后端·面试·github
JavaPub-rodert11 小时前
用 go-commons 打造更优雅的字符串处理工具
开发语言·后端·golang
老华带你飞13 小时前
学生信息管理系统|基于Springboot的学生信息管理系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·学生信息管理系统
Fency咖啡14 小时前
Spring 基础核心 - SpringMVC 入门与请求流程
java·后端·spring·mvc