同一SQL语句在PLSQL Developer与SQL * PLUS工具中执行结果不一致

背景

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

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工具执行结果以下
bash

在SQL*PLUS中执行结果以下
工具

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

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

分析

仔细观察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)

再次执行的结果以下code

  • PLSQLDeveloper工具
    it

  • SQL*PLUS工具
    字符编码

解决

此SQL执行形成不一样结果是由于中文字符致使的。class

因此咱们能够调整SSH工具的字符编码与设置NLS_LANG参数,经调整以后,SQLPLUS工具也能输出正确结果。

export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"

相关文章
相关标签/搜索