MySql数据库常用指令(三)MySQL 索引1

MySql数据库常用指令(三)

MySQL 索引是一种数据结构,用于加快数据库查询的速度和性能。

MySQL 索引的建立对于 MySQL 的高效运行是很重要的,索引可以大大提高 MySQL 的检索速度。

注:文中TEST为测试所用数据库,根据实际应用修改

一、创建索引

CREATE INDEX 语句可以创建普通索引:

CREATE INDEX index_name

ON table_name (column1 [ASC|DESC], column2 [ASC|DESC], ...);

~~

注: CREATE INDEX: 用于创建普通索引的关键字。 index_name: 指定要创建的索引的名称。索引名称在表中必须是唯一的。

table_name: 指定要在哪个表上创建索引。 (column1, column2, ...):

指定要索引的表列名。你可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期。 ASC和DESC(可选):

用于指定索引的排序顺序。默认情况下,索引以升序(ASC)排序。

~~

sql 复制代码
mysql> CREATE INDEX idx_name ON test (name);

注:在test表的name列上创建一个普通索引idx_name

二、修改表结构(添加索引)

ALTER TABLE 命令可以在已有的表中创建索引:

ALTER TABLE table_name

ADD INDEX index_name (column1 [ASC|DESC], column2 [ASC|DESC], ...);

注: ALTER TABLE: 用于修改表结构的关键字。 table_name: 指定要修改的表的名称。

ADD INDEX:添加索引的子句。ADD INDEX用于创建普通索引

index_name: 指定要创建的索引的名称。索引名称在表中必须是唯一的。

(column1, column2, ...):指定要索引的表列名。你可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期。

ASC和DESC(可选):用于指定索引的排序顺序。默认情况下,索引以升序(ASC)排序。

sql 复制代码
mysql>ALTER TABLE test ADD INDEX idx_age (age);

注:在 test 表的 age 列上创建一个名为 idx_age 的普通索引。

三、创建表的时候直接指定

CREATE TABLE 语句中直接指定索引,以创建表和索引的组合:

CREATE TABLE table_name (

column1 data_type,

column2 data_type,

...,

INDEX index_name (column1 [ASC|DESC], column2 [ASC|DESC], ...)

);

CREATE TABLE: 用于创建新表的关键字。

table_name: 指定要创建的表的名称。

(column1, column2,...): 定义表的列名和数据类型。你可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期

INDEX:用于创建普通索引的关键字。

index_name: 指定要创建的索引的名称。索引名称在表中必须是唯一的。

(column1,column2, ...): 指定要索引的表列名。可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期。

ASC和DESC(可选): 用于指定索引的排序顺序。默认情况下,索引以升序(ASC)排序。

sql 复制代码
mysql> CREATE TABLE test (
  id INT PRIMARY KEY,
  name VARCHAR(50),
  age INT,
  INDEX idx_age (age)
);

注:在test 表的 age 列上创建了一个名为 idx_age 的普通索引。

四、删除索引的语法

  1. 使用 DROP INDEX 语句来删除索引;

    DROP INDEX index_name ON table_name;

    DROP INDEX: 用于删除索引的关键字。

    index_name: 指定要删除的索引的名称。

    ON table_name:指定要在哪个表上删除索引。

    sql 复制代码
     mysql> DROP INDEX idx_age ON test;

    注:在 test 表中删除一个名为idx_age 的普通索引。

  2. 使用ALTER TABLE 语句删除索引:

    ALTER TABLE table_name DROP INDEX index_name;

    ALTER TABLE: 用于修改表结构的关键字。 table_name: 指定要修改的表的名称。 DROP INDEX:

    用于删除索引的子句。 index_name: 指定要删除的索引的名称。

    复制代码
      sql mysql> ALTER TABLE test DROP INDEX idx_age ;

    注:在 test 表中删除一个名为idx_age 的普通索引。

五、唯一索引

CREATE UNIQUE INDEX 语句创建唯一索引:

唯一索引确保索引中的值是唯一的,不允许有重复值。

CREATE UNIQUE INDEX index_name

ON table_name (column1 [ASC|DESC], column2 [ASC|DESC], ...);

CREATE UNIQUE INDEX: 用于创建唯一索引的关键字组合

index_name:指定要创建的唯一索引的名称。索引名称在表中必须是唯一的。

table_name: 指定要在哪个表上创建唯一索引。

(column1, column2, ...): 指定要索引的表列名。可以指定一个或多个列作为索引的组合。这些列的数据类型通常是数值、文本或日期。

ASC和DESC(可选): 用于指定索引的排序顺序。默认情况下,索引以升序(ASC)排序。

sql 复制代码
mysql> CREATE UNIQUE INDEX idx_name ON test (name);

注:在test 表的 name 列上创建一个名为 idx_name 的唯一索引

相关推荐
小乌龟不会飞5 分钟前
Ubuntu 安装 etcd 与 etcd-cpp-apiv3
数据库·etcd
程序员岳焱7 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
计算机毕设定制辅导-无忧学长8 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳8 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、9 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机9 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7
IT_10249 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
Johny_Zhao9 小时前
Ubuntu系统安装部署Pandawiki智能知识库
linux·mysql·网络安全·信息安全·云计算·shell·yum源·系统运维·itsm·pandawiki
祁思妙想10 小时前
八股学习(三)---MySQL
数据库·学习·mysql
惊骇世俗王某人10 小时前
1.MySQL之如何定位慢查询
数据库·mysql