informix的esql编译参数避免//注释引起的SQL中断问题
发表于:2025-02-13 作者:千家信息网编辑
千家信息网最后更新 2025年02月13日,在EXEC SQL中,如果SQL语句出现了"//"符号,那么会导致后面一直到";"结尾的SQL语句都被忽略,而不止当前行。这样往往会出乎程序员的意料。例如以下例子程序t1.ec。int main(){
千家信息网最后更新 2025年02月13日informix的esql编译参数避免//注释引起的SQL中断问题int main()
{
EXEC SQL UPDATE vyktd
SET kahaoo="1" //注释1出现在SQL中
WHERE kahaoo= "2";
//注释2出现在普通程序中
return 0;
}
在EXEC SQL中,如果SQL语句出现了"//"符号,那么会导致后面一直到";"结尾的SQL语句都被忽略,而不止当前行。这样往往会出乎程序员的意料。
例如以下例子程序t1.ec。
正常编译可以通过:
$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
$
注释
编译
程序
语句
参数
普通
危险
例子
可以通过
字句
条件
程序员
符号
隐患
意料
更新
问题
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
疫情银行系统网络安全
c 怎么根据数据库主键选择
国内技术最好的网络技术
高二网络安全专业
工业网络技术相关的证书
江苏师范大学数据库考试试卷
数据库管理软件的五大功能
网络安全靠人民的认识
软件开发有没有创新点
世界纯净生存服务器推荐
陕西地电节点服务器调用失败
兰州软件开发服务商
深圳市极数网络技术有限公司
服务器安全狗闪退
数据库技术基础学校
平板电脑如何打开数据库
网络安全主题辩论
怎么清理健康的数据库
双喜软件开发效果如何
民间是如何获得商标局数据库
达梦数据库unity
qt免费版连接数据库系统
去哪租用服务器比较好
服务器里怎么做32k的指令
湛江网络技术
方舟海贼服务器多钱
天津 软件开发 项目
白云app软件开发排名
深圳市极数网络技术有限公司
erp wms软件开发