sql中的if else 的一个小陷阱

2023-11-06

今天遇到一个特别奇葩的问题。一个存储过程“SP_MODI_TPAYNOTICE_ZHONGTAI”有如下代码。

DECLARE @V_USER_ID INT

.............

IF @V_USER_ID = 5 BEGIN
    --同步修改事物正文
        EXEC @V_RET = SP_INNER_MODI_TPAYNOTICEINFO_USERID5  @IN_PROBLEMID           SP_INNER_MODI_TPAYNOTICEINFO_USERID5 是一个存储过程
        IF @V_RET < 0 RAISERROR('Error raise in SP_INNER_MODI_TPAYNOTICEINFO_USERID5',16,99)
      --划款指令、非划款指令设定流程线路
SELECT @V_IS_HKZL = SUBSTRING(FK_TYPE,3,1) FROM TPAYNOTICE WHERE PROBLEMID = @IN_PROBLEMID
       IF @V_IS_HKZL = 1
BEGIN
UPDATE TPROBLEMS SET STATE_TYPE = 205 WHERE PROBLEMID = @IN_PROBLEMID
END
ELSE
BEGIN
UPDATE TPROBLEMS SET STATE_TYPE = 206 WHERE PROBLEMID = @IN_PROBLEMID
END
 END
 EXEC @V_RET = SP_MODI_TCOMMCREDIT_DESCRIPTION @IN_PROBLEMID,@IN_FK_BUSI_ID
    IF @V_RET < 0 RAISERROR('Error raise in SP_INNER_MODI_TPAYNOTICEINFO_USERID5',16,99)


    ELSE
    BEGIN
    --同步修改事物正文
        EXEC @V_RET = SP_INNER_MODI_TPAYNOTICEINFO_USERID7 @IN_PROBLEMID       //SP_INNER_MODI_TPAYNOTICEINFO_USERID7 是一个存储过程
        IF @V_RET < 0 RAISERROR('Error raise in SP_INNER_MODI_TPAYNOTICEINFO_USERID7',16,99)
    END

由上下文,@V_USER_ID 的值确实是5,(我查询了数据库),但事务的结果明显表示这里执行的是“SP_INNER_MODI_TPAYNOTICEINFO_USERID7”这个过程,一开始没注意,就怀疑@V_USER_ID 这个值的获取的时候是不是有什么失误,或者调用的时候是不是根本不是调用的这个过程,所以才会出现这么莫名其妙的结果。尝试过从调用这个存储过程的java代码开始复查,是否有哪些遗漏导致调的是别的存储过程。也尝试过是不是@V_USER_ID 的类型有问题。曾经将@V_USER_ID 的类型改为INTEGER,试过改成

if(ISNULL(@V_USER_ID,0) =5,试过if(ISNULL(@V_USER_ID,0) == 5。均已失败告终。最后经过一层层的定位,问题肯定出在这里,再仔细一看,在if @V_USER_ID = 5 

else begin ... end 中间有一段代码 EXEC @V_RET = SP_MODI_TCOMMCREDIT_DESCRIPTION @IN_PROBLEMID,@IN_FK_BUSI_ID,就是这一段代码将严格if else 语句生生拆成了两个语句,导致后面的SP_INNER_MODI_TPAYNOTICEINFO_USERID7 也被执行,而这个过程跟SP_INNER_MODI_TPAYNOTICEINFO_USERID5 大同小异,而把SP_INNER_MODI_TPAYNOTICEINFO_USERID5 给覆盖掉了。


所以,sql 中if else语句中间不能加多余语句,它会将这个判断结构拆分为两个语句,而且没有语法错误。不像java,java对于这样的错误编译根本通不过。

由此可见,基础的重要性。这么一个小问题整整折腾了一天。


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

sql中的if else 的一个小陷阱 的相关文章

随机推荐

  • Selenium RemoteWebDriver 利用CDP修改User-Agent

    地球人都知道 如果使用selenium时要修改user agent可以在启动浏览器时添加配置项 如chromeOptions addArguments user agent xxx 但是如何在每次请求的时候动态更改user agent呢 经
  • 计算机成下一个土木了吗?

    前些年抓住了互联网行业的红利期 进入大厂的员工 基本可以实现在一线城市买房扎根 但反观现在 被毕业 逃离互联网 躺平算了 却成了这个行业的主旋律 不少人在谈论润到国企和外企去了 也放低了对工资的预期 转而追求稳定和平衡 互联网行业真的不行了
  • YOLOv3(Pytorch版本和Tensorflow版本)学习

    一 地址来源 YOLOv4最全复现代码合集 含PyTorch TF Keras和Caffe等 二 Pytorch版本 地址 https github com Tianxiaomo pytorch YOLOv4 这个地址支持训练 Requir
  • 记一个正式的shell 2进制文件编辑方法。

    鉴于shell本身能力有限 不能用重定向的方法来实现较为正式的2进制文件修改 google无果 下面的实现还是比较满意的 1 printf或者echo n e来打印需要的内容到文件 2 dd插入内容 比如想在一个文件a bin的0x300位
  • 太阳能板如何串联_一步步教你搭建属于你自己的太阳能系统

    太阳能板种类 单晶硅太阳能板 单晶硅太阳能板的光电转换效率为15 左右 最高的达到24 这是所有种类的太阳能板中光电转换效率最高的 但制作成本很大 以致于它还不能被大量广泛和普遍地使用 由于单晶硅一般采用钢化玻璃以及防水树脂进行封装 因此其
  • springboot 自定义异常

    1 创建一个自定义异常类ManualException java 自定义异常类 author cf public class ManualException extends RuntimeException 错误代码 private Int
  • 未来10年互联网的十大发展趋势

    Written by Richard MacManus 刘明君译 我们已经现在进入被称为web 2 0的网络时代 这个阶段互联网的特征包括搜索 社区化网络 网络媒体 音乐 视频等 内容聚合和聚集 RSS mashups 一种交互式Web 应
  • dataloader的长度

    数据集 batchsize 比如数据集共有10582张图片 batchsize设为26 那么 len dataloader 10582 26 407
  • linux重启mysql服务_Linux怎么重启MySQL

    Linux怎么重启MySQL 从程序安装包安装的Mysql 在系统中没有红帽常用的servcie mysqld restart这个脚本 因此重启MYSQL数据库 只好手工重启 直接执行Killall mysql 强制终止的话 将可能造成表的
  • 虚拟数字人chatGPT结合?时代大革新?

    随着人工智能技术的快速发展 虚拟数字人和聊天机器人ChatGPT成为了越来越多人们日常生活中的重要伙伴 虚拟数字人可以陪伴人们聊天 解答问题 执行一些简单的任务 而ChatGPT则是一款领先的人工智能聊天机器人 具备强大的自然语言处理能力
  • 为WinDbg设置符号文件路径

    WinDbg可以通过加载Symbol文件 pdb 即时的调试程序 WinDbg如何找到相应的符号文件呢 WinDbg首先在 exe或者 dll所在目录下寻找同名的 pdb文件 如果找不到 WinDbg在Symbol File Path中查找
  • npm报错:A complete log of this run can be fund in: C\Users\用户\AppData\Roaming\npm-cache_logs\解决方案

    因项目中安装模块 多次不成功 所以导致报错 A complete log of this run can be fund in C Users 用户 AppData Roaming npm cache logs 2018 9 24T10 5
  • 《动手学深度学习 Pytorch版》 2.3 线性代数

    2 3 1 标量 import torch 标量由只有一个元素的张量表示 可进行熟悉的算数运算 x torch tensor 3 0 y torch tensor 2 0 x y x y x y x y x y tensor 3 tenso
  • scrapy 环境搭建

    在win7环境下 以window7 64bit安装为例子 1 下载python2 7环境 用浏览器打开https www python org downloads 然后选择所对应的版本 这里选择2 7 11 下载完成之后安装 在安装界面的时
  • twitter 分享链接_链接您的Twitter Feed

    twitter 分享链接 click here 请单击此处 So you want to display your Twitter status on your blog No problem use the API But what if
  • * 引领华为:任正非的七大领导力启示

    中国有诗云 江山代有才人出 各领风骚数百年 的确 任正非制定了最为有效的战略 让华为成长为一家全球领先的企业 这证明了他的巨大影响力和远见卓识 在本文里 大卫 德克莱默和田涛探讨了帮助华为取得巨大成功的七大领导力启示 中欧关系源远流长 自中
  • c语言中错误c2084,错误_C2084_函数“int multi(int)”已有主体

    file1 c中的程序 int multi int a return a a 文件file2 c中的程序 include file1 c int squsum int pt int i 0 sum 0 for i 0 i lt 5 i su
  • Mybatis框架

    什么是Mybits 是一款优秀的持久层框架 他是支持制定SQL 存储过程以及高级映射 它避免了几乎所有JDBC代码和手动设置参数 以及获取结果集 是一种可以 使用XML或者注解来配置和映射 支持动态sql以及数据缓存 将结果映射成java的
  • 微信小程序返回弹出提示

    当用户进入页面 编辑后没有保存直接返回 这时需要给用户提示是否需要保存在返回 如果保存了 则不提示 主要用到 wx enableAlertBeforeUnload Object object 开启小程序页面返回询问对话框 wx disabl
  • sql中的if else 的一个小陷阱

    今天遇到一个特别奇葩的问题 一个存储过程 SP MODI TPAYNOTICE ZHONGTAI 有如下代码 DECLARE V USER ID INT IF V USER ID 5 BEGIN 同步修改事物正文 EXEC V RET SP