如果所示,需要把字符串中存在的英文双引号 " " 转换成中文双引号 “ ”
2条回答 默认 最新
关注
如果不要求成对的话,直接用replace就好了,英文双引号是不存在左右的,但中文双引号有左右之分
replace(字段名,'"','“ ')
如果要求左右成对,可能就有点麻烦,因为不确定这个字符串中是否存在中英文双引号混用,以及是否存在多对双引号的情况,不能简单的按单数位置的双引号改成左双引号,双数位置的双引号改成右双引号,因此在不清楚数据到底有哪些可能性的情况下,这个可能都得靠机器学习来识别语义了。
但如果只有一对双引号,结合用substr结合instr,或者用正则替换都可以处理,以下sql为示意select substr(a, 1, instr(a, '"', 1, 1) - 1) || '左' || substr(a, instr(a, '"', 1, 1) + 1, instr(a, '"', 1, 2) - instr(a, '"', 1, 1)-1) || '右' || substr(a, instr(a, '"', 1, 2) + 1) from (select 'sdasf"214fgfv"wfff' a from dual);
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报