【OceanBase诊断调优】—— 如何缩短OceanBase 数据库执行 count(*) 的时间

本文介绍影响 OceanBase 数据库执行 count(*) 时间的因素以及缩短 count(*) 执行时间的方法。

适用版本

OceanBase 数据库所有版本

执行 count(*) 的时间

OceanBase 数据库中,执行 count(*) 的时间不仅与选择的行数,还与行的长度相关。这是由于对主表的扫描代价与行长度是相关的。

如何缩短 count(*) 的执行时间

如果您希望在更短的时间执行 count(*),可以通过以下两个方式进行规避。

  • 在查询中通过 SQL Hint 指定并行度。例如指定并行度为 16。

    复制代码
    obclient> SELECT /*PARALLEL(16)*/ count(*) FROM $table;
  • 为主表创建一个只包含一列的索引。

    例如为 $tableid 列创建索引。

    复制代码
    obclient> CREATE INDEX ind ON $table(id);
相关推荐
KIDAKN几秒前
Redis 分布式锁
数据库·redis·分布式
程序新视界8 分钟前
如何为MySQL中的JSON字段设置索引
数据库·mysql
Ultipa17 分钟前
查询语言的进化:SQL之后,为什么是GQL?数据世界正在改变
数据库·sql·图数据库·gql
LB211219 分钟前
SQL隐式链接显式连接
大数据·数据库·sql
隔壁阿布都1 小时前
spring boot + mybatis 使用线程池异步修改数据库数据
数据库·spring boot·mybatis
MAGICIAN...8 小时前
【Redis】--持久化机制
数据库·redis·缓存
我真的是大笨蛋9 小时前
JVM调优总结
java·jvm·数据库·redis·缓存·性能优化·系统架构
步步为营DotNet10 小时前
5-2EFCore性能优化
数据库·性能优化·.net
2501_9200470311 小时前
Redis-集群
数据库·redis·bootstrap
半夏陌离11 小时前
SQL 拓展指南:不同数据库差异对比(MySQL/Oracle/SQL Server 基础区别)
大数据·数据库·sql·mysql·oracle·数据库架构