4

语境

我们正在更改我们的安装脚本以使用 ant 的“sql”任务和 jdbc,而不是专有的 sql 客户端 sqlplus (oracle) 和 osql (msft)。

更新:添加了更多上下文。我们的“基础数据”(种子数据)由一组 .sql 文件组成,这些文件包含“供应商中立”(即在 oracle 和 mssql 中都可以使用)sql 语句。

问题

脚本运行良好,但有一个例外:

此 sql 在 Oracle 中失败。具体来说,某些东西(ant 或 jdbc 驱动程序)将破折号/连字符视为“注释的开头”——即使它们嵌入在字符串中。请注意,相同的 sql 可以与 ant/sql 和 microsoft 的 jdbc 驱动程序一起正常工作。

INSERT INTO email_client (email_client_id,generated_reply_text) VALUES(100002,'----- Original Message -----');

相关错误

这个蚂蚁错误似乎可以识别问题。由于它仍然开放(8 年后),我不希望很快修复。但是,由于该问题仅出现在 oracle 中,因此可能出在驱动程序上。

oracle驱动:jdbc瘦驱动,版本10.2.0.1.0

问题

有没有人有在 mssql 和 oracle 中都可以使用的解决方法?(例如更改违规行以定义转义字符?我在“插入”sql92 语法上没有看到“转义”)

谢谢

4

2 回答 2

5

查看“SQLExec”源并打开详细日志记录后,我找到了一种解决方法:

解决方法

如果 sql 语句包含一个包含“--”的字符串,则将分隔符(分号)放在下一行。

这失败了

INSERT INTO email_client (email_client_id,generated_reply_text) VALUES(100002,'----- Original Message -----');

这成功了

请注意,分号在单独的行上

INSERT INTO email_client (email_client_id,generated_reply_text) VALUES(100002,'----- Original Message -----')
;

细节

打开详细日志记录,我看到当 Ant 遇到有问题的 sql 语句时,它实际上一次将三个 sql 语句传递给了 jdbc 驱动程序。违规语句、下一个语句(也包括嵌入的“--”)和后续语句(不包括嵌入的“--”)。

我快速浏览了 Ant 代码,没有发现任何明显的错误。由于我不打算修补 Ant,因此我寻找了一种解决方法。

调整它,我发现如果我只是将分隔符(分号)移动到嵌入“--”的语句的下一行,脚本就会成功执行。

感谢大家参与

于 2012-09-18T19:33:11.963 回答
0

你可以试试这个:

INSERT INTO email_client (email_client_id,generated_reply_text)
VALUES(100002,LPAD('-',5,'-') || ' Original Message ' || LPAD('-',5,'-'));
于 2012-09-18T04:25:46.210 回答