今天遇到以下问题,同一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"