首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL——如何快速删除

前言 线上有一个,大小为24G左右,没有什么重要数据,却一直没有优化,导致业务无法进行,在此环境上,所以我们开始了删除之路 步骤 复制表 我这里使用Navicat工具直接复制表,选择仅结构即可。...创建硬链接 如果不知道自己存储位置,可使用show variables like "datadir";查看自己数据存储位置。...ln instruction.frm instruction.frm.bak ln instruction.ibd instruction.ibd.bak 删除 DROP TABLE "表格名";...24G数据删除大概用了15秒左右 修改名 将我们刚才复制,名修改为线上正常使用名即可。...删除物理文件 切记大物理文件不可直接删除,直接操作会导致磁盘IO和CPU利用率升高,影响线上业务可使用truncate来进行删除操作。

2700
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL查看数据库重复记录并删除

,phone from user group by username,phone HAVING count(*) >1); 注意:where条件(username,phone)括号不能少不然会报错。...删除用户名和手机号都相同重复记录 DELETE from user where (username,phone) -- 注意:此处一定要加括号,当成联合字段来处理 IN ( --...HAVING COUNT(1) > 1 ); 上述语句看着是不是应该正常能执行删除掉用户名和手机号都相同重复记录只保留id最小那一条。...实际执行会报如下错误: 1093 - You can’t specify target table ‘user’ for update in FROM clause 含义:不能在同一查询数据作为同一更新数据...; INSERT INTO `user`(`id`, `username`, `phone`, `age`) VALUES (1, '我是主数据库zjq', '13666666666', 18);

10.8K30

删除MySQL重复数据?

前言一般我们将数据存储在MySQL数据库,它允许我们存储重复数据。但是往往重复数据是作废、没有用数据,那么通常我们会使用数据库唯一索引 unique 键作为限制。...那么如何在一个普通数据库删除重复数据呢?那我用一个例子演示一下如何操作。。。...和 不等于 2.同时删除业务主键数据那么便有以下几个查询:/*1、查询中有重复数据主键*/select rd2.iccId from flow_card_renewal_comparing rd2...rd2 GROUP by rd2.iccId having count(rd2.iccId)>1 )or iccId is null注意一点是mysql删除时候会提示不能用查询结果来做删除操作,...这个时候就需要将查询数据作为一个临时,起别名进行删除啦。

7.2K10

②【MySQL操作】 数据库创建、查询、修改、删除

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习路上摸爬滚打,记录学习过程~ 个人主页:.29.博客 学习社区:进去逛一逛~ 数据库创建、查询、...数据类型 数据库数据类型: 数值类型: TINYINT:小整数 SMALLINT:大整数 MEDIUMINT:大整数,范围大于SMALLINT INT/INTEGER:大整数,范围大于MEDIUMINT...DDL - 操作 DDL-操作: 查询信息 ①查询当前数据库所有 SHOW TABLES; ②查询结构 DESC 名; ③查询指定建表语句 SHOW CREATE TABLE 名; 创建操作...括号括起来是可选参数,可以不写 CREATE TABLE 名( 字段1 字段1类型 [COMMENT 字段1注释], 字段2 字段2类型 [COMMENT 字段2注释], 字段3...] 名; -- 演示 -- 删除名为aaa -- 执行时,如果aaa不存在,报错: -- 错误代码: 1051 Unknown table '名' DROP TABLE aaa; -- 使用关键字

47250

InnodbMySQL如何快速删除2T

共享空间:某一个数据库所有的数据,索引文件全部放在一个文件,默认这个共享空间文件路径在data目录下。 默认文件名为:ibdata1(此文件,可以扩展成多个)。....frm文件:保存了每个元数据,包括结构定义等,该文件与数据库引擎无关。 .ibd文件:保存了每个数据和索引文件。...在数据库mytest,有一个,名为erp,执行下列命令 mysql> system ls -l /data/mysql/mytest/  得到下面的输出(我过滤了一下) -rw-r----- 1...现在就是erp.ibd文件太大,所以删除卡住了。 如何解决这个问题呢? 这里需要利用了linux硬链接知识,来进行快速删除。...那么,这时删除,已经把table从mysql删除。但是磁盘空间,还没释放,因为还剩一个文件erp.ibd.hdlk。 如何正确删除erp.ibd.hdlk呢?

2.9K20

如何快速删除InnoDB

背景 在使用MySQL时,如果有大存储引擎是InnoDB,并且系统参数innodb_file_per_table设置为1,即每个文件对应一个独立空间,当对这些大进行DROP TABLE时,有时会发现整个数据库系统性能会有显著下降...在删除一个有独立空间时,需要对buffer pool中所有和这个空间有关数据页做清理工作,包括从AHI,flush list和LRU list上移除,而在这个清理过程,会一直持有buffer...IO问题 尽管已经有了上述buffer pool层面的优化,我们在使用MySQL 5.6或者5.7时依然发现删除对系统性能还是会产生显著影响,说明DROP TABLE还有其他性能瓶颈,尤其是对于这样一种业务场景...dict_sys->mutex dict_sys->mutex是用来保护内存数据字典,以及mysql库下数据字典,从源码可以看到,在unlink ibd文件之前,所有的数据字典操作已经结束,其实是可以释放掉...过程调整为: 获取dict_sys->mutex这个数据字典锁 启动一个innodb事务 更新数据字典,包括内存数据和mysql库下数据字典 lazy drop逻辑,清理buffer pool

8.7K32

清空删除mysql

Mysql清空(truncate)与删除数据(delete)区别 为某基于wordpress搭建博客长久未除草,某天升级时候发现已经被插入了几万条垃圾留言,如果一条条删除那可真是累人活。...遂考虑直接进入mysql直接清空或者删除数据。 本文记录一下这2种操作模式区别,目标对象是wp_comments,里面的所有留言均是垃圾留言,均可删除。...然后便有了以下2种方式(进入mysql操作界面后): truncate table wp_comments; delete * from wp_comments; 其中truncate操作table...这两者都是将wp_comments数据清空,不过也是有区别的,如下: truncate是整体删除(速度较快), delete是逐条删除(速度较慢)。...而delete删除以后,Identity依旧是接着被删除最近那一条记录ID加1后进行记录。 如果只需删除部分记录,只能使用DELETE语句配合where条件。

8.1K20

mysql清空数据_mysql数据库如何清空数据「建议收藏」

大家好,又见面了,我是你们朋友全栈君。 本篇文章主要讲述是在数据库中使用清空命令,具有一定学习价值,有需要朋友可以了解一下,希望能够对你有所帮助。...在做数据迁移,数据清洗或者写web项目时要将数据替换更新,那么有时要将做清空处理 常用清空数据SQL语句有如下两种delete from 名;truncate table 名; 运行测试 我使用是...MySql待测试有20000条记录,将其多拷两份以备测试 分别运行两个清空SQL语句 从结果可以看出两条语句都可以达到清空目的,而两者区别是: truncate效率高于delete...truncate 清除数据后不记录日志,不可以恢复数据,相当于保留mysql结构,重新创建了这个,所有的状态都相当于新. delete清除数据后记录日志,可以恢复数据,相当于将中所有记录一条一条删除...具体选用哪一种方法要根据实际遇到情况而定,我通常使用是delete方法,虽然时间较慢,但是较为保险 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/132304

9.6K40

如何防止插入删除造成数据库死锁

数据库中经常会遇到这样情况:一个主表A,一个子表B,B包含有A主键作为外键。当要插入数据时候,我们会先插入A,然后获得AIdentity,再插入B。...如果要进行删除操作,那么就先删除子表B,然后再删除主表A。在程序设计,对两个操作是在一个事务之中完成。 当系统使用频繁就会出现插入操作和删除操作同时进行情况。...2 删除A数据之前,先使用一个事务将B相关外键指向另外A另外一个数据(比如在A中专门建一行数据,主键设置为0,永远不会对这行数据执行删除操作),这样就消除了要被删除数据在AB两个关系...然后就可以使用删除事务,先删除A数据,再删除B数据,以达到和插入事务访问一致,避免死锁。...3 在外键关系,将“删除规则”设置为“层叠”,这样删除事务只需要直接去删除主表A,而不需要对子表B进行操作。因为删除规则设置为层叠以后,删除主表数据,子表中所有外键关联数据也同时删除了。

1.4K30

MySQL 如何查询包含某字段

' and table_type='base table' and table_name like '%_copy'; information_schema 是MySQL系统自带数据库,提供了对数据库元数据访问...information_schema.tables 指数据库(information_schema.columns 指列) table_schema 指数据库名称 table_type 指是类型...(base table 指基本,不包含系统) table_name 指具体名 如查询work_ad数据库是否存在包含”user”关键字数据 select table_name from...,如何查询包含某字段 select * from systables where tabname like 'saa%' 此法只对Informix数据库有用 查询指定数据库中指定所有字段名...table_name = 'd_ad'; 如何查询mysql数据库中有多少张 select count(*) TABLES, table_schema from information_schema.tables

12.4K40

MySQL异步删除方法

背景在MySQL中有大需要清理,该超过100GB,不敢直接delete或者truncate、drop,怕影响业务。...truncate会清空所有行,但结构及其约束、索引等保持不变;drop会删除结构及其所依赖约束、索引等。truncate会重置自增值;delete不会。...常见删除方式对于大场景,常见做法:小批量、分批删除;由于直接使用delete,是逐步删除,直接delete不带where条件肯定是不科学。.../product/236/48904实现原理如下:将ibd文件名重命名为临时文件名,临时文件存放在 innodb_async_drop_tmp_dir 指定目录下在后台线程逐步truncate ....,由内核自动完成,其原理是在删除时,为数据文件在另外一个目录创建一个硬连接。

4.4K110
领券