我们使用 Flyway 1 个月以来没有遇到任何问题。
但是,今天我尝试添加一个非常长(超过1500行)的新迁移脚本,并遇到了一个奇怪的MySQL语法错误。
我在 MySQL Workbench 中打开这个脚本,没有报告语法错误,脚本执行没有错误。
这个名为“V10012__insert-acceptance-testing-event-moment-passed.sql”的脚本包含以下说明。
- 插入语句1
- 插入语句2
- ...
- INSERT 语句最后 - 1
- 最后插入语句
MySQL报告的错误如下:
[错误] 由 com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException 引起:您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,了解在第 232 行的 'INSERT INTO video_feedback (id, youtube_video_id) VALUES ( 1102, /* id */' at line 232 [ERROR] com.googlecode.flyway.core. migration.MigrationException:迁移到版本 10012 失败!请恢复备份并回滚数据库和代码!
该错误是在“INSERT statements LAST”语句上报告的。
但是,如果我在脚本中反转“INSERT 语句 LAST”和“INSERT 语句 LAST - 1”,则会在“INSERT 语句 LAST - 1”(现在位于文件末尾)上报告错误。所以我在“INSERT statements LAST”中没有错误,因为 Flyway 成功执行了它。
另外,如果现在我从脚本“V10012_ insert-acceptance-testing-event-moment-passed.sql”中完全删除“INSERT statements LAST”语句,并将该语句放入名为“V10013 _test.sql”的新文件中,flyway 会执行我所有的迁移脚本都成功了!
那么,我最初的“V10012__insert-acceptance-testing-event-moment-passed.sql”脚本中可能存在什么问题?
是否存在脚本大小限制?
以下是有关我的环境的有用信息:
- 我的脚本使用了大量 /* */ 注释
- Flyway …