我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么解决MYSQL中的Errcode: 17 - File exists问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么解决MYSQL中的Errcode: 17 - File exists问题

本篇内容主要讲解“怎么解决MYSQL中的Errcode: 17 - File exists问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决MYSQL中的Errcode: 17 - File exists问题”吧。

现象:

执行show fields from a时报下面的错误

Error: Can't create/write to file '/tmp/#sql_419_0.MYI' (Errcode: 17 - File exists): SHOW FULL FIELDS FROM `a`

解决方法:

在/tmp下,把相关的#sql文件移除即可

重现:

[root@10-19-187-240 tmp]# ll | grep sql
-rw-r--r-- 1 root  root    531453 1月  10 19:55 a.sql
lrwxrwxrwx 1 root  root        25 1月   9 18:14 mysql.sock -> /var/lib/mysql/mysql.sock
-rw-rw---- 1 mysql mysql    98304 1月  21 21:23 test.ibd
-rw-rw---- 1 mysql mysql        7 1月  22 11:15 t_myisam.MYD
-rw-rw---- 1 mysql mysql     1024 1月  22 11:15 t_myisam.MYI


show fileds 开始执行时:
[root@10-19-187-240 tmp]# ll | grep sql
-rw-r--r-- 1 root  root    531453 1月  10 19:55 a.sql
lrwxrwxrwx 1 root  root        25 1月   9 18:14 mysql.sock -> /var/lib/mysql/mysql.sock
-rw-rw---- 1 mysql mysql        0 2月  14 14:20 #sql_5ec_0.MYD
-rw-rw---- 1 mysql mysql     1024 2月  14 14:20 #sql_5ec_0.MYI
-rw-rw---- 1 mysql mysql    98304 1月  21 21:23 test.ibd
-rw-rw---- 1 mysql mysql        7 1月  22 11:15 t_myisam.MYD
-rw-rw---- 1 mysql mysql     1024 1月  22 11:15 t_myisam.MYI
[root@10-19-187-240 tmp]#
[root@10-19-187-240 tmp]#
[root@10-19-187-240 tmp]# cp "#sql_5ec_0.MYD" ~/
[root@10-19-187-240 tmp]# cp "#sql_5ec_0.MYI" ~/

show filelds 执行完成 后:
[root@10-19-187-240 tmp]# ll | grep sql
-rw-r--r-- 1 root  root    531453 1月  10 19:55 a.sql
lrwxrwxrwx 1 root  root        25 1月   9 18:14 mysql.sock -> /var/lib/mysql/mysql.sock
-rw-rw---- 1 mysql mysql    98304 1月  21 21:23 test.ibd
-rw-rw---- 1 mysql mysql        7 1月  22 11:15 t_myisam.MYD
-rw-rw---- 1 mysql mysql     1024 1月  22 11:15 t_myisam.MYI
[root@10-19-187-240 tmp]#
[root@10-19-187-240 tmp]#

把原来的文件 copy回来
[root@10-19-187-240 tmp]# cp ~/"#sql_5ec_0.MYD" ./
[root@10-19-187-240 tmp]# cp ~/"#sql_5ec_0.MYI" ./
[root@10-19-187-240 tmp]# ll
总用量 20532
-rw-r--r-- 1 root  root    531453 1月  10 19:55 a.sql
drwxr-xr-x 6 root  root      4096 1月  12 14:50 data
-rw-r--r-- 1 root  root  20376794 1月  14 21:34 data.zip
lrwxrwxrwx 1 root  root        25 1月   9 18:14 mysql.sock -> /var/lib/mysql/mysql.sock
-rw-r----- 1 root  root         0 2月  14 14:21 #sql_5ec_0.MYD
-rw-r----- 1 root  root      1024 2月  14 14:21 #sql_5ec_0.MYI
-rw-rw---- 1 mysql mysql    98304 1月  21 21:23 test.ibd
-rw-rw---- 1 mysql mysql        7 1月  22 11:15 t_myisam.MYD
-rw-rw---- 1 mysql mysql     1024 1月  22 11:15 t_myisam.MYI

再次执行show fields

怎么解决MYSQL中的Errcode: 17 - File exists问题

就可以重现上面的错误

调用过程:

#0  fill_schema_table_by_open (thd=0x2293ee0,
    is_show_fields_or_keys=true, table=0x7fbed405c310,
    schema_table=0x1531980, orig_db_name=0x7fbf00dfea20,
    orig_table_name=0x7fbf00dfea10,
    open_tables_state_backup=0x7fbf00dfe8b0,
    can_deadlock=false)
    at /data/mysql-5.6.35/sql/sql_show.cc:3470
#1  0x000000000084107e in get_all_tables (thd=0x2293ee0,
    tables=0x7fbed4006090, cond=0x0)
    at /data/mysql-5.6.35/sql/sql_show.cc:4131
#2  0x000000000084f655 in do_fill_table (thd=0x2293ee0,
    table_list=0x7fbed4006090, join_table=0x7fbed4065358)
    at /data/mysql-5.6.35/sql/sql_show.cc:7433
#3  0x000000000084fa2c in get_schema_tables_result (
    join=0x7fbed405aae0,
    executed_place=PROCESSED_BY_JOIN_EXEC)
    at /data/mysql-5.6.35/sql/sql_show.cc:7534
#4  0x00000000008238c7 in JOIN::prepare_result (
    this=0x7fbed405aae0, columns_list=0x7fbf00dfeda0)
    at /data/mysql-5.6.35/sql/sql_select.cc:822
#5  0x00000000007c10ef in JOIN::exec (this=0x7fbed405aae0)
    at /data/mysql-5.6.35/sql/sql_executor.cc:116
#6  0x0000000000824408 in mysql_execute_select (
    thd=0x2293ee0, select_lex=0x2296478, free_join=true)
    at /data/mysql-5.6.35/sql/sql_select.cc:1101
#7  0x000000000082471f in mysql_select (thd=0x2293ee0,
    tables=0x7fbed4006090, wild_num=0, fields=...,
    conds=0x0, order=0x2296640, group=0x2296578,
    having=0x0, select_options=2684619520,
    result=0x7fbed405aab8, unit=0x2295e30,
    select_lex=0x2296478)
    at /data/mysql-5.6.35/sql/sql_select.cc:1222
#8  0x000000000082273b in handle_select (thd=0x2293ee0,
    result=0x7fbed405aab8, setup_tables_done_option=0)
    at /data/mysql-5.6.35/sql/sql_select.cc:110
#9  0x00000000007fb93e in execute_sqlcom_select (
    thd=0x2293ee0, all_tables=0x7fbed4006090)
    at /data/mysql-5.6.35/sql/sql_parse.cc:5181
#10 0x00000000007f4081 in mysql_execute_command (
    thd=0x2293ee0)
    at /data/mysql-5.6.35/sql/sql_parse.cc:2689
---Type <return> to continue, or q <return> to quit---
#11 0x00000000007fe4bc in mysql_parse (thd=0x2293ee0,
    rawbuf=0x7fbed4005030 "show fields from a", length=18,
    parser_state=0x7fbf00e00670)
    at /data/mysql-5.6.35/sql/sql_parse.cc:6433
#12 0x00000000007f0f7d in dispatch_command (
    command=COM_QUERY, thd=0x2293ee0,
    packet=0x2368eb1 "show fields from a",
    packet_length=18)
    at /data/mysql-5.6.35/sql/sql_parse.cc:1372
#13 0x00000000007eff56 in do_command (thd=0x2293ee0)
    at /data/mysql-5.6.35/sql/sql_parse.cc:1039
#14 0x00000000007b5f35 in do_handle_one_connection (
    thd_arg=0x2293ee0)
    at /data/mysql-5.6.35/sql/sql_connect.cc:982
#15 0x00000000007b5cca in handle_one_connection (
    arg=0x2293ee0)
    at /data/mysql-5.6.35/sql/sql_connect.cc:899
#16 0x0000000000b33da0 in pfs_spawn_thread (arg=0x21e64c0)
    at /data/mysql-5.6.35/storage/perfschema/pfs.cc:1860
#17 0x00007fbf2c56faa1 in start_thread ()
   from /lib64/libpthread.so.0
#18 0x00007fbf2b2d8aad in clone () from /lib64/libc.so.6

经过一步步的查看,发现是在
create_tmp_table (thd=0x2293ee0, param=0x7fbed405a050,
fields=..., group=0x0, distinct=false,
save_sum_fields=false, select_options=2147752704,
rows_limit=18446744073709551615,
table_alias=0x7fbed4006088 "COLUMNS")
at /data/mysql-5.6.35/sql/http://sql_tmp_table.cc:455
生成的临时表。
实际上是查看了information_schema中的表

到此,相信大家对“怎么解决MYSQL中的Errcode: 17 - File exists问题”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么解决MYSQL中的Errcode: 17 - File exists问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中的filesort问题怎么解决

在MySQL中,filesort是指MySQL使用文件进行排序操作。通常情况下,filesort是由于MySQL无法使用索引进行排序而导致的,可能是因为查询语句中没有合适的索引,或者索引失效等原因。解决filesort问题的方法有以下几种
mysql中的filesort问题怎么解决
2024-05-22

MySQL中怎么解决幻读问题

本篇文章给大家分享的是有关MySQL中怎么解决幻读问题,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、什么是幻读?  假设我们有表t结构如下,里面的初始数据行为:(0,0,0
2023-06-20

mysql中explain filtered问题怎么解决

在MySQL中,EXPLAIN语句用于分析查询的执行计划,提供了关于查询语句的有用信息。其中,filtered字段用于表示查询结果集中的行数占总行数的比例。如果EXPLAIN语句返回的filtered值较低,表示查询结果集中的行数较多,可
mysql中explain filtered问题怎么解决
2024-04-09

mysql中flush hosts问题怎么解决

在MySQL中,"flush hosts"语句用于清除主机缓存表,以便重新加载主机名和IP地址的映射。如果你遇到了“flush hosts”问题,可以尝试以下解决方法:检查权限:确保你有足够的权限执行“flush hosts”命令。通常,只
mysql中flush hosts问题怎么解决
2024-04-09

编程热搜

目录