蟹不肉@123 2022-10-23 15:28 采纳率: 50%
浏览 38
已结题

Oracle中字段截取汉字

Oracle中字段有一行是这样的格式 : [["测","试"],["平","台"]]
引号中间是汉字
想要用SQL语句达到这样的效果 : 测试,平台
请问下有什么好的办法吗?

  • 写回答

1条回答 默认 最新

  • lichuanjai 2022-10-23 19:45
    关注

    --建表
    CREATE TABLE AAA(A VARCHAR2(50));
    --插数据
    INSERT INTO AAA VALUES('[["测","试"],["平","台"]]');
    COMMIT;
    --查看表内数据
    SELECT * FROM AAA;
    --方法1,替换,截取
    SELECT SUBSTR(REPLACE(REPLACE(REPLACE(REPLACE(A,'[',''),']',''),'"',''),',',''),1,2)||','||SUBSTR(REPLACE(REPLACE(REPLACE(REPLACE(A,'[',''),']',''),'"',''),',',''),3,2) FROM AAA;
    --方法2,直接截取
    SELECT SUBSTR(A,4,1)||SUBSTR(A,8,1)||','||SUBSTR(A,14,1)||SUBSTR(A,18,1) FROM AAA;
    --方法3,直接整个替换
    SELECT REPLACE(A,'[["测","试"],["平","台"]]','测试,平台') FROM AAA;
    --你自己根据实际情况看着用;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月3日
  • 已采纳回答 10月26日
  • 创建了问题 10月23日