对MySQL进行debug和普通程序有所不同,主要是没有配置文件的情况下直接debug。过程如下:
1. 对源码进行cmake 编译(进入到build文件夹),make -j20,
2. 在build文件夹下,进入mysql-test,运行mtr程序:
./mtr --manual-debug load
3. 上面的mtr相当于和mysqld的沟通进程,后面的参数有个load,其对应的文件为load.test,位置被我创建于mysql源码中的ls ~/AliSQL-5.7/mysql-test/t, 内容是:
CREATE TABLE t1 (S1 INT, S2 INT);
CREATE Index t1_idx on t1(S1);
INSERT INTO t1 VALUES (1, 1);
INSERT INTO t1 VALUES (2, 2);
INSERT INTO t1 VALUES (3, 3);
INSERT INTO t1 VALUES (4, 4);
INSERT INTO t1 VALUES (5, 5);
INSERT INTO t1 VALUES (6, 6);
INSERT INTO t1 VALUES (7, 7);
SELECT * FROM t1 WHERE S1 > 1 and S1 < 5 or S1 > 3 and S1 < 7;
4. 运行了mtr之后,会在屏幕上看到一堆输出的结果,类似于:
--defaults-group-suf