如何跳过校验MySQL 5.7 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:
1. 配置 innodb_force_recovery可以使 srv_force_recovery != 0 ,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。2. 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。
临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。
1、ORDERBY的索引优化。如果一个SQL语句形如:
SELECT
[column1],[column2],….
FROM
[TABLE]
ORDER
BY
[sort]
在[sort]这个栏位上建立索引就可以实现利用索引进行order
by
优化。
2、WHERE
+
ORDER
BY的索引优化,形如:
SELECT
[column1],[column2],….
FROM
[TABLE]
WHERE
[columnX]
=
[value]
ORDER
BY
[sort]
建立一个联合索引(columnX,sort)来实现order
by
优化。
注意:如果columnX对应多个值,如下面语句就无法利用索引来实现order
by的优化
SELECT
[column1],[column2],….
FROM
[TABLE]
WHERE
[columnX]
IN
([value1],[value2],…)
ORDER
BY[sort]
3、WHERE+
多个字段ORDER
BY
SELECT
*
FROM
[table]
WHERE
uid=1
ORDER
x,y
LIMIT
0,10
建立索引(uid,x,y)实现order
by的优化,比建立(x,y,uid)索引效果要好得多。
MySQL
Order
By不能使用索引来优化排序的情况
*
对不同的索引键做
ORDER
BY
:(key1,key2分别建立索引)
SELECT
*
FROM
t1
ORDER
BY
key1,
key2
*
在非连续的索引键部分上做
ORDER
BY:(key_part1,key_part2建立联合索引key2建立索引)
SELECT
*
FROM
t1
WHERE
key2=constant
ORDER
BY
key_part2
*
同时使用了
ASC
和
DESC:(key_part1,key_part2建立联合索引)
SELECT
*
FROM
t1
ORDER
BY
key_part1
DESC,
key_part2
ASC
*
用于搜索记录的索引键和做
ORDER
BY
的不是同一个:(key1,key2分别建立索引)
SELECT
*
FROM
t1
WHERE
key2=constant
ORDER
BY
key1
*
如果在WHERE和ORDER
BY的栏位上应用表达式(函数)时,则无法利用索引来实现order
by的优化
SELECT
*
FROM
t1
ORDER
BY
YEAR(logindate)
LIMIT
0,10
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)