2

为了将数据库从 oracle 迁移到 mysql,我正在使用 ddlutils。迁移架构适用于我的目的,但由于缺少行,插入数据失败。日志文件的以下摘录对此进行了解释:

[ddlToDatabase] About to execute SQL: INSERT INTO `RECORDSTATUS` (`NAME_ID`, RECORDSTATUS_ID`, `NAME`, `SORTVALUE`) VALUES (?, ?, ?, ?)
[ddlToDatabase] Inserted bean RECORDSTATUS:RECORDSTATUS_ID=0
...
[ddlToDatabase] Defering insertion of row NAME:LANGUAGE_ID=0;NAME_ID=5941 because it is waiting for:
[ddlToDatabase]   RECORDSTATUS:RECORDSTATUS_ID=0

在数据库中,有一行 RECORDSTATUS_ID=0。有人遇到同样的问题吗?有人有想法,问题是什么?

4

2 回答 2

1

从 MySql 迁移到 DerbyDB 时,我遇到了类似的问题。我的情况是,实际问题是 DDLUtils 只处理那些针对主键的外键。

因此,如果您有包含一些唯一非主键字段的 MASTER 表,并且您有引用(外键)到该唯一非主键字段的 DETAILS 表,DDLUtils 无法将 DETAILS 记录链接到 MASTER,因此根本无法插入 DETAIL 记录.

这是 DDLUtils 1.0 版中的情况。

我对代码进行了一些快速(并且可能是肮脏的)修改,它似乎解决了这个问题。修改后的版本可以在这里下载(包括源代码):DllUtils-1.0_mod_with_src.jar。您可以自行承担使用它的风险。

最好的问候卡里苏拉卡

于 2011-08-05T08:49:06.867 回答
0
INSERT INTO `RECORDSTATUS` (`NAME_ID`, RECORDSTATUS_ID`, `NAME`, `SORTVALUE`) VALUES 

应该:

INSERT INTO `RECORDSTATUS` (`NAME_ID`, `RECORDSTATUS_ID`, `NAME`, `SORTVALUE`) VALUES 
于 2011-06-27T12:14:36.593 回答