luoshuang401 2014-01-03 06:18 采纳率: 0%
浏览 2127

sql脚本insert语句过长,导入报错

今天在用mysql导入sql脚本时,报错"MySQL server has gone away",经检测,是“insert...value...”里数据过多导致不能插入。后修改配置文件:

 1.tmp_table_size
 2.max_allowed_packet

仍旧报同样的错。来位大神解决了吧,真揪心。

ps:最好是通过调整mysql配置参数,因为sql不是本人写的。

  • 写回答

1条回答

  • 混分吴老师 2023-04-07 20:12
    关注

    如果 SQL 脚本中的 INSERT 语句过长,导致导入时报错,可以考虑以下几个解决方法:

    1. 分割 INSERT 语句:将一长串的 INSERT 语句拆分成多个小的 INSERT 语句,每个 INSERT 语句只插入一行数据。这样可以避免一次性插入过多数据导致的问题。例如:

      INSERT INTO table_name (column1, column2, column3) VALUES (value1, value2, value3);
      INSERT INTO table_name (column1, column2, column3) VALUES (value4, value5, value6);
      INSERT INTO table_name (column1, column2, column3) VALUES (value7, value8, value9);
      
    2. 使用 LOAD DATA 语句:如果数据量较大,可以考虑使用 LOAD DATA 语句将数据从文件中导入。这样不仅可以避免 INSERT 语句过长的问题,还可以提高导入效率。例如:

      LOAD DATA INFILE '/path/to/file.csv' INTO TABLE table_name FIELDS TERMINATED BY ',' LINES TERMINATED BY '\n';
      

      这条语句将从指定文件中读取数据,并将其插入到指定的表中。

    3. 压缩 SQL 文件:如果 SQL 文件过大,可以考虑将其压缩为 gzip 或 zip 格式,然后再导入。这样可以减小文件大小,从而避免导入时出现的问题。例如:

      gzip sql_file.sql
      mysql -u username -p dbname < sql_file.sql.gz
      

      这两条命令将先将 SQL 文件压缩为 gzip 格式,然后使用 mysql 命令将其导入到指定数据库中。

    以上是一些常见的解决方法,如果问题仍然存在,可以考虑分批导入数据,或者使用第三方工具进行导入。

    评论

报告相同问题?

悬赏问题

  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮