CRON 正在改变编码?

Cod*_*nci 8 cron files encoding

我有一个输出 SQL 脚本的旧 Java 程序。然后我使用 Apache Derby 在目标数据库(与 CRON 不在同一台服务器上)上运行该 SQL。

当通过腻子运行时,这工作正常。在 Windows 中运行时,这工作正常。使用 CRON 运行时,Derby 将 £ 符号读取为 ?。

如果我查看生成的 sql 脚本(使用 VI),它包含 £ 符号。但是,如果我检查数据库,它包含?。

为什么在 CRON 下运行它会使程序的行为有所不同?

Cod*_*nci 6

看来 CRON 是问题所在。Java 程序运行时,将结果输出到文件中时,未能正确写入。我正在阅读的 SQL 文件指向错误的版本。

为了解决这个问题,我在 CRON 脚本的顶部附近添加了以下代码

export LANG = en_US.UTF-8
Run Code Online (Sandbox Code Playgroud)

这确保了 £ 符号的格式正确。