zoukankan      html  css  js  c++  java
  • 同一SQL语句在PLSQL Developer与SQL * PLUS工具中执行结果不一致

    背景

    今天遇到如下问题,同一sql语句在PLSQL Developer与SQL*PLUS工具中执行结果不一致,

    sql语句如下

    SELECT 'GROUPHEALTH_SEND_EMAIL' as interface,
    SUM(decode(se.status, 1, 0, 1)) AS count
    , 0 AS processed
    , SUM(decode(se.status, 1, 0, 1)) - 0 AS notprocessed
    FROM cuan_doic.policy po
    LEFT JOIN cuan_doic.role ro ON ro.topactualid = po.topactualid
    AND ro.kind = 'BASICRISKINFOPA' 
    LEFT JOIN cuan_doic.property pr ON pr.parentactualid = ro.actualid
    AND pr.topactualid = po.topactualid
    AND pr.kind = 'GROUPTYPE' 
    LEFT JOIN  cuan_doic.t_sendemailinfo se ON po.policyno = substr(emailcontent, INSTR(se.emailcontent, '保单号:', 1, 1) + 4, 12)
    AND se.senderowner = 'UW_WECHAT' 
    WHERE 1 = 1
    AND po.productcode = '00130001'
    AND po.CURRENTFLAG = 'Y'
    AND pr.value = '$$600062000006'
    AND po.policyno IS NOT NULL;
    

    在PLSQLDeveloper工具执行结果如下

    在SQL*PLUS中执行结果如下

    出现这种问题时候,有些老司机会问,是不是连接的数据库不一致,用户不一致,表的数据是不是一致?

    经确认以上都是一致的,只是执行SQL的工具不一致。

    分析

    仔细观察SQL语句,有如下连接条件。
    
    ON po.policyno = substr(emailcontent, INSTR(se.emailcontent, '保单号:', 1, 1) + 4, 12)
    
    这里有中文字符,是不是这个导致的? 为证实自己的想法,把中文字符用英文代替。
    
    
    ON po.policyno = substr(emailcontent, INSTR(se.emailcontent, 'bdh', 1, 1) + 4, 12)
    

    再次执行的结果如下

    • PLSQLDeveloper工具

    • SQL*PLUS工具

    解决

    此SQL执行造成不同结果是因为中文字符导致的。

    所以我们可以调整SSH工具的字符编码与设置NLS_LANG参数,经调整之后,SQLPLUS工具也能输出正确结果。

    export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"

  • 相关阅读:
    shell 知识点
    辅助字符串处理类:org.apache.commons.lang3.StringUtils
    post请求(headers里有属性)报错:Request header field xxx is not allowed by Access-Control-Allow-Headers in preflight response
    vue-cli 打包报错:Unexpected token: punc (()
    遍历对象,并对其中第一个(随机)进行处理
    JavaScript中类似PHP的uniqid()方法
    使用crypto-js的md5加密
    Yarn、MapReduce、spark、storm的关系
    hadoop 知识点
    spring cloud 知识点
  • 原文地址:https://www.cnblogs.com/wanbin/p/9514666.html
Copyright © 2011-2022 走看看