carrot 1 2022-02-17 16:46 采纳率: 33.3%
浏览 76
已结题

oracle怎么写函数把英文双引号转化成中文双引号?

img


如果所示,需要把字符串中存在的英文双引号 " " 转换成中文双引号 “ ”

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-02-17 17:04
    关注

    如果不要求成对的话,直接用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);
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月5日
  • 已采纳回答 2月25日
  • 创建了问题 2月17日