在MySQL中,索引是一种可以提高数据检索效率的数据结构。MySQL提供了多种索引类型,包括主键索引、唯一索引、全文索引、组合索引、和范围查询索引等。
主键索引(Primary Key)
主键索引是最常用的索引类型之一,它保证了表中每一行数据的唯一性。
CREATE TABLE my_table (
id INT NOT NULL,
username VARCHAR(16) NOT NULL,
PRIMARY KEY (id)
);
唯一索引(Unique)
唯一索引保证了列中的每个值都是唯一的。
CREATE TABLE my_table (
id INT NOT NULL,
username VARCHAR(16) NOT NULL,
UNIQUE (username)
);
全文索引(FULLTEXT)
全文索引用于全文检索,特别适合于查找文本中的关键字。
CREATE TABLE my_table (
id INT NOT NULL,
content TEXT NOT NULL,
FULLTEXT (content)
);
组合索引
组合索引是由多个列组合形成的索引,只有在查询条件中使用了这些列的左边部分时,索引才会被使用。
CREATE TABLE my_table (
id INT NOT NULL,
username VARCHAR(16) NOT NULL,
age INT NOT NULL,
INDEX (username, age)
);
范围查询索引
范围查询索引适用于 =, <>, >, >=, <, <=, IS NULL, <=>等操作符。
CREATE TABLE my_table (
id INT NOT NULL,
age INT NOT NULL,
INDEX (age)
);
以上代码展示了如何在创建表时定义索引,也可以在表创建后使用ALTER TABLE
或CREATE INDEX
语句来添加或修改索引。
在实际应用中,应根据具体的查询需求来选择合适的索引类型和列,以提高查询效率。