PURGE_LOG()
函数说明
PURGE_LOG()
用于删除记录于 MatrixOne 数据库系统表中的日志。返回 0 表示删除成功;删除失败则返回报错信息。
Note
目前,仅有 root 用户(即集群管理员,具有 MOADMIN
权限)拥有执行 PURGE_LOG()
函数以进行日志删除操作的权限。
函数语法
> PURGE_LOG('sys_table_name', 'date')
参数释义
参数 | 说明 |
---|---|
‘sys_table_name’ | 当前可进行删除的系统表仅三个:metric,rawlog,statement_info。 Note: ‘sys_table_name’ 必须用引号包裹。 |
‘date’ | 选择日期,删除该日期之前产生的日志。 Note: ‘date’ 必须用单引号包裹。 |
Note
MatrixOne 有且仅有 metric,rawlog,statement_info 三张系统日志表,有关这三张表的详细信息请参考 MatrixOne 系统数据库和表。
示例
- 示例 1:
-- 删除 2023-06-30 这一天之前的 statement_info 类型的日志
mysql> select purge_log('statement_info', '2023-06-30') a;
+------+
| a |
+------+
| 0 |
+------+
1 row in set (0.01 sec)
- 示例 2:
-- 查询 metric 日志采集的时间和数量
mysql> select date(collecttime), count(1) from system_metrics.metric group by date(collecttime);
+-------------------+----------+
| date(collecttime) | count(1) |
+-------------------+----------+
| 2023-07-07 | 20067 |
| 2023-07-06 | 30246 |
| 2023-07-05 | 27759 |
+-------------------+----------+
3 rows in set (0.04 sec)
-- 删除 2023-07-06 这一天之前的 rawlog,statement_info,和 metric 三种类型的日志
mysql> select purge_log('rawlog, statement_info, metric', '2023-07-06');
+-------------------------------------------------------+
| purge_log(rawlog, statement_info, metric, 2023-07-06) |
+-------------------------------------------------------+
| 0 |
+-------------------------------------------------------+
1 row in set (0.33 sec)
-- 再次查询 2023-07-05,2023-07-06 和 2023-07-07 这三天的 metric 日志数量
mysql> select date(collecttime), count(1) from system_metrics.metric group by date(collecttime);
+-------------------+----------+
| date(collecttime) | count(1) |
+-------------------+----------+
| 2023-07-06 | 30246 |
| 2023-07-07 | 20121 |
+-------------------+----------+
2 rows in set (0.01 sec)