mysql使用的坑

Posted Lucian

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql使用的坑相关的知识,希望对你有一定的参考价值。

一:

mysql默认是安装记录的物理顺序取数据的,如果不加order by 排序,可能得不到预期的结果。

(1) 获取 两个时间点的 id  (很快)

$sql = ‘select id from apply_info where create_time< {$now} limit 1’;   (要加  order by id desc)

获得 idNow

$sql = ‘select id from apply_info where create_time>= {$yesterday} limit 1’ (要加 order by id asc)

获得 idYt

(2) 每次取 1000

do{

       select user_mobile,user_from from apply_info where  id <= {$idNow} limit 1000;

       idNow -= 1000;

       //toDo

} while (idNow >= idYt)

 二:

当使用limit时,explain可能会造成误导

(1)explain估计行数,不考虑limit,可能会对查询估计过多的检查行数

(2)类似于SELECT ... FROM TBL LIMIT N这样的查询因为用不到索引将要报告为慢查询,(如果N不大,实际很快)

配置文件设置min-examined-row-limit=Num of Rows,检查的行数>=这个量的查询才会被报告为慢查询,避免误判

(3)类似于这样的select .. from tb where key_part1= ? order by key_part2 limit n,explain也要估计出过多的检查行数

以上是关于mysql使用的坑的主要内容,如果未能解决你的问题,请参考以下文章

Mysql中 begin..end使用遇到的坑

几个django 2.2和mysql使用的坑

VS2017 + EF + MySQL 我使用过程中遇到的坑

windows中使用mysql配置my.ini时的坑

MySQL中使用group_concat遇到的坑

Pycharm添加Mysql數據庫的坑