MySQL常用SQL
登录数据库
mysql -h localhost -P 3306 -u root
登录数据库后导出数据库
mysqldump -u root -p 数据库名 > /www/脚本名称.sql
线上无锁添加索引online DDL,只能通过ALTER TABLE不能create index
ALTER TABLE 表名 ADD INDEX 索引名(列名), ALGORITHM=INPLACE, LOCK=NONE;
添加主键索引
ALTER TABLE 表名 ADD PRIMARY KEY (列名), ALGORITHM=INPLACE, LOCK=NONE;
添加FULLTEXT(全文索引)
ALTER TABLE 表名 ADD FULLTEXT(列名);
添加UNIQUE(唯一索引)
ALTER TABLE 表名 ADD UNIQUE(列名);
参数说明:
ALGORITHM=INPLACE 更优秀的解决方案,在当前表加索引,步骤: 1.创建索引(二级索引)数据字典 2.加共享表锁,禁止DML,允许查询 3.读取聚簇索引,构造新的索引项,排序并插 入新索引 4.等待打开当前表的所有只读事务提交 5.创建索引结束 ALGORITHM=COPY 通过临时表创建索引,需要多一倍存储,还有更多的IO,步骤: 1.新建带索引(主键索引)的临时表 2.锁原表,禁止DML,允许查询 3.将原表数据拷贝到临时表 4.禁止读写,进行rename,升级字典锁 5.完成创建索引操作 LOCK=DEFAULT:默认方式,MySQL自行判断使用哪种LOCK模式,尽量不锁表 LOCK=NONE:无锁:允许Online DDL期间进行并发读写操作。如果Online DDL操 作不支持对表的继续写入,则DDL操作失败,对表修改无效 LOCK=SHARED:共享锁:Online DDL操作期间堵塞写入,不影响读取 LOCK=EXCLUSIVE:排它锁:Online DDL操作期间不允许对锁表进行任何操作
创建索引,建议规范ids_字段名
CREATE INDEX 索引名称 ON 表名(字段);
显示索引列表
SHOW INDEX FROM table_name;
删除索引(要从表中删除现有索引,可使用DROP INDEX语句。)
DROP INDEX index_name ON table_name;
显示哪些线程正在运行。
SHOW PROCESSLIST;
通过命令查看慢查询:
select * from information_schema.processlist where command not in ('Sleep') and user not in ('mydba','event_scheduler','repl','binlogbak','system user')