今天遇到如下问题,同一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的工具不一致。
再次执行的结果如下:
PLSQLDeveloper工具
SQL*PLUS工具
此SQL执行造成不同结果是因为中文字符导致的。
所以我们可以调整SSH工具的字符编码与设置NLS_LANG参数,经调整之后,SQLPLUS工具也能输出正确结果。
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"转载于:https://www.cnblogs.com/wanbin/p/9514666.html
