如何合理的添加索引

我就想加个索引,怎么就这么难?

领导让我SQL优化,我直接把服务干挂了…

前言

MySQL大表加字段或者加索引,是有一定风险的。

大公司一般有DBA,会帮助开发解决这个痛点,可是DBA是怎么做的呢?

小公司没有DBA,作为开发我们的责任就更大了。那么我们怎么才能安全的加个索引呢?

今天,我们通过模拟案例以及原理分析,去弄清楚MySQL中DDL的风险,以及如何避免事故发生。

准备

软件以及项目

安装本地版本MySQL。

一个简单的增删改查项目。

使用JMeter进行并发请求测试。

创建表

如果存在user表则删除

DROP TABLE IF EXISTS user;

创建user表

CREATE TABLE user (
id bigint NOT NULL AUTO_INCREMENT COMMENT ‘自增主键’,
name varchar(10) DEFAULT NULL COMMENT ‘姓名’,
age int(2) DEFAULT NULL COMMENT ‘年龄’,
address varchar(30) DEFAULT NULL COMMENT ‘地址’,
description varchar(100) DEFAULT NULL COMMENT ‘描述’,
test_id bigint DEFAULT NULL COMMENT ‘测试 id’,
create_time timestamp NULL DEFAULT NULL COMMENT ‘创建时间’,
modify_time timestamp NULL DEFAULT NULL COMMENT ‘修改时间’,
PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT=‘mysql ddl测试表’;

创建存储过程

如果存在test存储过程则删除

DROP PROCEDURE IF EXISTS test;

创建无参存储过程,名称为test

CREATE PROCEDURE test()

BEGIN
# 声明变量
DECLARE i INT;
# 变量赋值
SET i = 0;
# 结束循环的条件: 当i等于100万时跳出while循环
WHILE i < 1000000 DO
# 往t_test表添加数据
INSERT INTO test.user (name, age, address,
description, test_id, create_time, modify_time)
VALUES (‘iisheng’, 26, ‘北京’, ‘如逆水行舟’, LAST_INSERT_ID() + 1,
‘2020-05-17 16:01:44’, ‘2020-05

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 MySQL 中添加索引的方法如下: 1. 进入数据库, 选择你想添加索引的表: ``` USE database_name; SELECT * FROM table_name; ``` 2. 使用 `CREATE INDEX` 语句创建索引: ``` CREATE INDEX index_name ON table_name (column_name); ``` 注意: - 可以在多个列上创建索引, 只需在括号内用逗号分隔列名即可. - 在同一个表中, 索引名称必须是唯一的. - 在添加索引之前, 请确保已经对表进行了适当的规划, 以便选择正确的列来创建索引. 例如, 下面的语句在 `customer` 表的 `last_name` 和 `first_name` 列上创建了一个名为 `name_index` 的索引: ``` CREATE INDEX name_index ON customer (last_name, first_name); ``` 希望这些信息对您有帮助! ### 回答2: 为了提高MySQL数据库的查询效率,可以通过添加索引来加快查询操作。MySQL支持多种索引类型,包括普通索引、唯一索引、主键索引、全文索引等。 添加索引的方式有两种:通过CREATE INDEX语句创建索引和通过ALTER TABLE语句修改表结构添加索引。 1. 通过CREATE INDEX语句创建索引: 格式:CREATE [UNIQUE] INDEX index_name ON table_name(column_name); 示例:CREATE INDEX idx_name ON user(name); 可选的UNIQUE关键字表示创建唯一索引,保证索引列的唯一性。索引名(index_name)用于区分不同的索引,表名(table_name)表示要添加索引的表名,列名(column_name)表示要为哪一列添加索引。 2. 通过ALTER TABLE语句修改表结构添加索引: 格式:ALTER TABLE table_name ADD [UNIQUE] INDEX index_name(column_name); 示例:ALTER TABLE user ADD INDEX idx_name(name); 添加索引时,也可以选择在现有索引的基础上添加新的列。索引名(index_name)可以不同于CREATE INDEX语句,关键字UNIQUE可选。 无论是哪种方式,添加索引都会对数据库的性能造成影响。索引的设计需要根据具体的业务需求和查询频率来决定,不宜过多或过少。过多的索引会增加数据库的维护成本,过少的索引则会降低查询效率。索引的选择不仅取决于需要查询的字段,还要考虑表的大小、读取和写入频率等因素。 总之,在使用MySQL数据库时,根据具体情况合理设计和添加索引,可以显著提高数据库的查询性能。 ### 回答3: 在MySQL中,可以通过以下几种方式来添加索引: 1. CREATE INDEX语句:可以在创建表时直接添加索引,语法如下: ``` CREATE TABLE table_name ( column1 data_type, column2 data_type, ... INDEX index_name (column1, column2, ... ) ); ``` 2. ALTER TABLE语句:可以在已存在的表上添加索引,语法如下: ``` ALTER TABLE table_name ADD INDEX index_name (column1, column2, ... ); ``` 3. CREATE UNIQUE INDEX语句:与CREATE INDEX类似,不同之处在于可以创建唯一索引,即索引列的值不能重复。 ``` CREATE TABLE table_name ( column1 data_type, column2 data_type, ... UNIQUE INDEX index_name (column1, column2, ... ) ); ``` 4. ALTER TABLE语句:与ALTER TABLE类似,可以在已存在的表上添加唯一索引。 ``` ALTER TABLE table_name ADD UNIQUE INDEX index_name (column1, column2, ... ); ``` 除了以上方式,还可以使用MySQL命令行或者可视化工具进行索引添加。在命令行中,可以使用`CREATE INDEX`和`ALTER TABLE`语句,而在可视化工具中,通常提供了图形界面来方便地添加和管理索引。 无论使用何种方式添加索引,都需要考虑以下几个因素: - 索引的列应选择在查询中频繁使用的列。 - 索引的列应具有高选择性,即其不同值的数量较大,这样可以提高索引的效率。 - 当表的数据量较大时,可以使用前缀索引来减小索引的大小。 - 仅在需要时添加索引,因为索引会增加数据插入和更新的开销。 总之,添加合适的索引可以提高数据库查询的速度和效率,但需要根据具体的业务需求和数据特点来进行决策。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值