0

我有一个 pl sql 字符串如下:

String := 'ctx_ddl.add_stopword(''"SHARK_IDX19_SPL"'',''can''); 

       create index "SCOTT"."SHARK_IDX2"
       on "SCOTT"."SHARK2"
       ("DOC")
          indextype is ctxsys.context
          parameters(''
            datastore       "SHARK_IDX2_DST"
           filter          "SHARK_IDX2_FIL"
           section group   "SHARK_IDX2_SGP"
           lexer           "SHARK_IDX2_LEX"
           wordlist        "SHARK_IDX2_WDL"
           stoplist        "SHARK_IDX2_SPL"
           storage         "SHARK_IDX2_STO"
           sync (every "SYSDATE+(1/1)" memory 67108864)
           '')
           /
       ';

我必须搜索最后出现的“/”并添加“;” 给它。我还需要转义参数('')中预设的引号以获得额外的引号。我需要像这样的输出

String := 'ctx_ddl.add_stopword(''"SHARK_IDX19_SPL"'',''can''); 

       create index "SCOTT"."SHARK_IDX2"
       on "SCOTT"."SHARK2"
       ("DOC")
          indextype is ctxsys.context
          parameters(''''
            datastore       "SHARK_IDX2_DST"
           filter          "SHARK_IDX2_FIL"
           section group   "SHARK_IDX2_SGP"
           lexer           "SHARK_IDX2_LEX"
           wordlist        "SHARK_IDX2_WDL"
           stoplist        "SHARK_IDX2_SPL"
           storage         "SHARK_IDX2_STO"
           sync (every "SYSDATE+(1/1)" memory 67108864)
           '''')
           /;
       ';

任何帮助。

4

1 回答 1

1

古语有云:“有些人在遇到问题时,会想‘我知道,我会用正则表达式。’现在他们有两个问题”

除非您遇到真正需要正则表达式的问题,否则我建议您使用基本的字符串操作函数。

分号: 使用 INSTR 查找最后出现的 '/',称之为 P1。
结果 = Substr 从位置 1 到 P1||';'||substr 从 P1+1 到字符串结尾

参数替换: 使用 INSTR 查找参数列表的开始位置(即在字符串中查找“parameters(”)和结束位置(可能是字符串中的最后一个右括号“)”)。将这些称为 P2 和 P3。

结果 = substr 从 1 到 P2 || 替换(从 P2+1 到 P3-1 的子串,'''','''''''')|| 从 P3 到字符串结尾的 substr

于 2015-09-14T06:51:54.520 回答