时间条件高效用法

1、问题

项目上接到业务是这样的,一个分区表5千万,然后要根据时间条件去分批更新数据。看了一眼已经写好的脚本,简化成下面的查询语句,我们来看看问题:

css 复制代码
select count(1) from TEST2 where date_format(ctime,'%Y-%m')='2026-02';
计划:
1   #NSET2: [1171, 1, 13] 
2     #PRJT2: [1171, 1, 13]; exp_num(1), is_atom(FALSE) 
3       #AAGR2: [1171, 1, 13]; grp_num(0), sfun_num(1), distinct_flag[0]; slave_empty(0)
4         #PARALLEL: [1171, 250000, 13]; scan_type(FULL), key_num(0, 0, 0), simple(0), range_sfun_opt(0)
5           #SLCT2: [1171, 10000000, 13]; exp11 = '2026-02'
6             #SSCN: [1171, 10000000, 13]; IDX_DM_TEST2_CTIME(TEST2); btr_scan(0); is_global(1)

这里我们可以看到ctime条件套用函数,结果计划中只能用索引全扫描,一般我们更希望条件上不要套用函数,这样可以用到普通索引。

2、改写

以上语句根据思路改写成如下:

css 复制代码
select count(1) from TEST2 where ctime>=to_date('2026-02-01 00:00:00','YYYY-MM-DD hh24:mi:ss') and ctime<to_date('2026-03-01 00:00:00','YYYY-MM-DD hh24:mi:ss');
计划:
1   #NSET2: [22, 1, 13] 
2     #PRJT2: [22, 1, 13]; exp_num(1), is_atom(FALSE) 
3       #AAGR2: [22, 1, 13]; grp_num(0), sfun_num(1), distinct_flag[0]; slave_empty(0)
4         #PARALLEL: [22, 174318, 13]; scan_type(FULL), key_num(0, 0, 0), simple(0), range_sfun_opt(0)
5           #SSEK2: [22, 174318, 13]; scan_type(ASC), IDX_DM_TEST2_CTIME(TEST2), scan_range[exp11,exp11), is_global(1)

改写后从原来的4.5s变成0.013s

3、小结

时间条件我们总是习惯在上面套用函数,这样可能导致用不上普通索引。要养成习惯,不要在时间条件上套用函数。

相关推荐
2301_813599552 小时前
Go语言怎么做秒杀系统_Go语言秒杀系统实战教程【实用】
jvm·数据库·python
NCIN EXPE6 小时前
redis 使用
数据库·redis·缓存
MongoDB 数据平台6 小时前
为编码代理引入 MongoDB 代理技能和插件
数据库·mongodb
极客on之路6 小时前
mysql explain type 各个字段解释
数据库·mysql
代码雕刻家6 小时前
MySQL与SQL Server的基本指令
数据库·mysql·sqlserver
lThE ANDE7 小时前
开启mysql的binlog日志
数据库·mysql
yejqvow127 小时前
CSS如何控制placeholder文字的颜色_使用--placeholder伪元素
jvm·数据库·python
oLLI PILO7 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
m0_743623927 小时前
HTML怎么创建多语言切换器_HTML语言选择下拉结构【指南】
jvm·数据库·python