2022
我们一起努力

informix的esql编译参数避免//注释引起的SQL中断问题 - 数据库

在EXEC SQL中,如果SQL语句出现了“//”符号,那么会导致后面一直到“;”结尾的SQL语句都被忽略,而不止当前行。这样往往会出乎程序员的意料。

例如以下例子程序t1.ec。

  • int main()
  • {
  •         EXEC SQL UPDATE vyktd
  •         SET kahaoo=”1” //注释1出现在SQL中
  •         WHERE kahaoo= ”2”;
  •         //注释2出现在普通程序中
  •         return 0;
  • }
  • 正常编译可以通过:

    $esql -e t1.ec

    $

    其实执行的SQL将会是UPDATE vyktd SET kahaoo=”1”,不带任何条件。因为WHERE字句被注释1所掩盖,变成危险的全表更新!

    为了避免这样的隐患,需要加上esql的编译参数-keepccomment,加上这个以后,如果在sql里写了“//”就会编译报错。

    $esql -keepccomment -e t1.ec
    esqlc: ”t1.ec”, line 4: Error -33051: Syntax error on identifier or symbol ’/’.
    1 error(s) found

    $

    赞(0)
    文章名称:《informix的esql编译参数避免//注释引起的SQL中断问题 - 数据库》
    文章链接:https://www.fzvps.com/96523.html
    本站文章来源于互联网,如有侵权,请联系管理删除,本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
    图片版权归属各自创作者所有,图片水印出于防止被无耻之徒盗取劳动成果的目的。

    评论 抢沙发

    评论前必须登录!