同一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"

posted @ 2018-07-25 17:01  DB-Engineer  阅读(1213)  评论(0编辑  收藏  举报