清理MySQL数据

1、清理binlog日志

测试过程中如果产生了大量binlog日志,如下:

901M mysql-bin.000015

903M mysql-bin.000016

901M mysql-bin.000017

901M mysql-bin.000018

901M mysql-bin.000019

901M mysql-bin.000020

901M mysql-bin.000021

901M mysql-bin.000022

903M mysql-bin.000023

901M mysql-bin.000024

901M mysql-bin.000025

901M mysql-bin.000026

901M mysql-bin.000027

903M mysql-bin.000028

901M mysql-bin.000029

903M mysql-bin.000030

901M mysql-bin.000031

901M mysql-bin.000032

901M mysql-bin.000033

可以使用如下命令删除binlog日志:

sql 复制代码
-- 'mysql-bin.000033' 根据实际情况修改
-- 会删除mysql-bin.000033之前的binlog日志
PURGE BINARY LOGS TO 'mysql-bin.000033';

2、清空表数据

如果表数据量较大,需要保留其中一些记录,删除剩余数据,可以使用如下命令实现:

表名:t_app

条件:保留 app_id = 666 的数据

sql 复制代码
-- 1. 创建新表(复制结构)
CREATE TABLE t_app_new LIKE t_app;

-- 2. 插入需要保留的数据
INSERT INTO t_app_new
SELECT *
FROM t_app
WHERE app_id != '666';

-- 3. 重命名表(原子操作,瞬间完成)
RENAME TABLE t_app TO t_app_old,
             t_app_new TO t_app;

-- 4. 确认无误后删除旧表
DROP TABLE t_app_old;
相关推荐
EasyCVR2 小时前
国标GB28181/RTSP/ONVIF/RTMP视频监控平台EasyCVR视频质量诊断花屏/蓝屏/画面模糊/冻结检测
网络·数据库·音视频
C^h2 小时前
RTthread中的内存池理解
linux·数据库·c++·算法·嵌入式
fobwebs2 小时前
wordpress 网站安装了Yoast SEO,并且做了内容的优化后,如果想重置Yoast SEO,并且删除所有的优化内容,应该如何操作?
数据库·yoast seo·重置yoast seo·清空yoast seo内容
路由侠内网穿透2 小时前
本地部署开源 LLM 应用观测与调试平台 Langfuse 并实现外部访问
运维·服务器·数据库·物联网·开源
SPC的存折2 小时前
1、Ansible之Ansible安装与入门
linux·数据库·ansible
qiumingxun2 小时前
mysql的分区表
数据库·mysql
李昊哲小课2 小时前
aiomysql 完整实战教程
python·mysql·pymysql·aiomysql
sxhcwgcy2 小时前
Spring Boot中集成MyBatis操作数据库详细教程
数据库·spring boot·mybatis
康康的AI博客2 小时前
向量数据库选型指南:AI 数据底座怎么选不踩坑
数据库·人工智能