SELECT a.id FROM ex_exam a LEFT JOIN ex_exam_statistic_enp_evaluate b ON a.id = b.qlh_exam_id WHERE a.type IN ("EXAM_EX_NORMAL_TYPE_NORMAL", "EXAM_TYPE_RZ") AND b.qlh_exam_id IS NULL 优化一下
时间: 2023-08-15 17:03:57 浏览: 46
该查询语句已经比原来的语句进行了优化,但是还可以进一步优化。以下是一些可能的优化方案:
1. 添加索引
可以为 ex_exam 表和 ex_exam_statistic_enp_evaluate 表的相关字段添加索引,以提高查询效率。例如,可以为 ex_exam 表的 type 字段添加索引,为 ex_exam_statistic_enp_evaluate 表的 qlh_exam_id 字段添加索引。
2. 分批处理
如果查询的数据量过大,可以将查询结果分批处理,以减少单次查询的数据量。可以使用 LIMIT 和 OFFSET 关键字来实现分批查询,例如:
```
SELECT a.id
FROM ex_exam a
LEFT JOIN ex_exam_statistic_enp_evaluate b ON a.id = b.qlh_exam_id
WHERE a.type IN ("EXAM_EX_NORMAL_TYPE_NORMAL", "EXAM_TYPE_RZ") AND b.qlh_exam_id IS NULL
LIMIT 10000 OFFSET 0;
```
该语句每次查询 10000 条记录,并通过 OFFSET 关键字来指定查询的起始位置。可以多次执行该语句,直到查询完所有符合条件的记录为止。
3. 使用 EXISTS
可以使用 EXISTS 关键字来代替 LEFT JOIN 和 IS NULL,例如:
```
SELECT a.id
FROM ex_exam a
WHERE a.type IN ("EXAM_EX_NORMAL_TYPE_NORMAL", "EXAM_TYPE_RZ") AND NOT EXISTS (
SELECT 1
FROM ex_exam_statistic_enp_evaluate b
WHERE a.id = b.qlh_exam_id
)
```
该语句的效率与使用 LEFT JOIN 的语句类似,但是使用 EXISTS 更加简洁明了。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![7z](https://img-home.csdnimg.cn/images/20210720083312.png)