MySQL如何删除#sql开头的临时表
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL如何删除#sql开头的临时表,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2013字,纯文字阅读大概需要3分钟。
内容图文
![MySQL如何删除#sql开头的临时表](/upload/InfoBanner/zyjiaocheng/521/95586379bd954f2ca5f2ee2d039672e6.jpg)
注: #mysql50#前缀是MySQL 5.1中引入的文件名安全编码。另外,表名因不符合命名规范,想要执行该脚本需要将表名用反引号括起来。
3.2 创建新表方式删除
因为本例中没有存在.frm 和.ibd名称相同的文件的情况,因此采用创建一张与ibd表空间对应的结构(字段名及索引)一致的表,然后将frm文件拷贝为和ibd一致的文件,再进行删除。
下面处理截图中#sql-ib1516-2335726735.ibd文件,步骤如下:
a) 创建一张与#sql-ib1516-2335726735相同的表
root@testdb 08:47:35>create table company20191216 like company; Query OK, 0 rows affected (0.05 sec) root@testdb 08:48:59>exit Bye
b) 拷贝为#sql-ib1516-2335726735.frm的定义文件
[root@db4 testdb]# cp -p company20191216.frm \#sql-ib1516-2335726735.frm
c) 删除表
因为上一步拷贝时使用-p的方式,即权限和原文件权限一致,属主及group均为mysql,因此可以直接在数据库里读取删除,如果权限不对,必须先修改文件权限。
root@testdb 08:49:54>drop table `#mysql50##sql-ib1516-2335726735`; Query OK, 0 rows affected (6.65 sec)
此时,135G的文件就已经删掉了(其实另一个文件#sql-821_2.frm文件也一并删了)
注: 删除这种100G的表不建议直接删除,而是通过创建硬链接的方式处理。
3.3 修改frm文件名与ibd文件名一致
上一步中删除ibd文件时,其中一个frm也自动删除了。为此,尝试通过修改frm文件名和ibd文件名一致的方式处理。但要注意,由于不确定是否结构一致,修改后可能异常,但如果没有暴力处理,通常均可以成功。如下:
a) 修改frm文件名与ibd文件名一致
[root@db4 testdb]# mv \#sql-a846_2.frm \#sql-ib1570-121877015.frm
b) 删除表
root@testdb 01:41:06>DROP TABLE `#mysql50##sql-ib1570-121877015`; Query OK, 0 rows affected (1.70 sec)
done!
其实还有其他的方式处理,大家可以自行测试。
参考资料:官方文档https://dev.mysql.com/doc/refman/5.7/en/innodb-troubleshooting-datadict.html
MySQL如何删除#sql开头的临时表
标签:参考资料 sql any 原因 logs algo roo 系统 文件名
本文系统来源:https://www.cnblogs.com/lonelyxmas/p/12500185.html
内容总结
以上是互联网集市为您收集整理的MySQL如何删除#sql开头的临时表全部内容,希望文章能够帮你解决MySQL如何删除#sql开头的临时表所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。