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

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日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵