MySQL索引是一种数据库对象,用于提高查询速度,它可以帮助数据库引擎快速定位到表中的指定数据,以下是关于MySQL索引的一些详细用法:
1、创建索引
创建索引可以使用CREATE INDEX
语句,语法如下:
CREATE INDEX index_name ON table_name (column_name);
为employees
表的last_name
列创建一个名为idx_last_name
的索引:
CREATE INDEX idx_last_name ON employees (last_name);
2、查看索引
使用SHOW INDEX
语句可以查看表中的所有索引,语法如下:
SHOW INDEX FROM table_name;
查看employees
表的所有索引:
SHOW INDEX FROM employees;
3、删除索引
使用DROP INDEX
语句可以删除表中的索引,语法如下:
DROP INDEX index_name ON table_name;
删除employees
表的idx_last_name
索引:
DROP INDEX idx_last_name ON employees;
4、主键索引
主键索引是唯一标识表中每一行数据的索引,一个表只能有一个主键索引,创建主键索引时,可以在列定义时添加PRIMARY KEY
约束。
CREATE TABLE employees ( id INT PRIMARY KEY, first_name VARCHAR(50), last_name VARCHAR(50) );
5、唯一索引
唯一索引是不允许表中存在重复值的索引,创建唯一索引时,可以在列定义时添加UNIQUE
约束。
CREATE TABLE employees ( id INT PRIMARY KEY, email VARCHAR(100) UNIQUE, first_name VARCHAR(50), last_name VARCHAR(50) );
6、普通索引(非唯一索引)
普通索引允许表中存在重复值的索引,创建普通索引时,不需要添加任何约束。
CREATE TABLE employees ( id INT PRIMARY KEY, email VARCHAR(100), first_name VARCHAR(50), last_name VARCHAR(50) );
7、全文索引(FULLTEXT)
全文索引用于全文搜索,只适用于MyISAM
和InnoDB
引擎的表,创建全文索引时,需要在列定义后添加FULLTEXT
关键字。
CREATE TABLE articles ( id INT PRIMARY KEY, title VARCHAR(100), content TEXT, FULLTEXT (title, content) );
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。