我有一个 Java 字符串,它实际上是一个 SQL 脚本。
CREATE OR REPLACE PROCEDURE Proc
AS
b NUMBER:=3;
c VARCHAR2(2000);
begin
c := 'BEGIN ' || ' :1 := :1 + :2; ' || 'END;';
end Proc;
我想用分号拆分脚本,除了那些出现在字符串中的脚本。所需的输出是四个不同的字符串,如下所述
1- CREATE OR REPLACE PROCEDURE Proc AS b NUMBER:=3
2- c VARCHAR2(2000)
3- begin c := 'BEGIN ' || ' :1 := :1 + :2; ' || 'END;';
4- end Proc
Java Split() 方法也会将上面的字符串拆分为标记。我想保留这个字符串,因为分号在引号内。
c := 'BEGIN ' || ' :1 := :1 + :2; ' || 'END;';
Java Split() 方法输出
1- c := 'BEGIN ' || ' :1 := :1 + :2
2- ' || 'END
3- '
请建议一个正则表达式,它可以在分号上分割字符串,除了那些在字符串中的字符串。
===================== CASE-2 ========================
以上部分已回答及其工作
这是另一个更复杂的案例
==================================================== ====
我有一个 SQL 脚本,我想标记每个 SQL 查询。每个 SQL 查询由分号 (;) 或正斜杠 (/) 分隔。
1-如果它们出现在类似的字符串中,我想转义分号或 / 符号
...WHERE col1 = 'some ; name/' ..
2- 表达式还必须转义任何多行注释语法,即 /*
这是输入
/*Query 1*/
SELECT
*
FROM tab t
WHERE (t.col1 in (1, 3)
and t.col2 IN (1,5,8,9,10,11,20,21,
22,23,24,/*Reaffirmed*/
25,26,27,28,29,30,
35,/*carnival*/
75,76,77,78,79,
80,81,82, /*Damark accounts*/
84,85,87,88,90))
;
/*Query 2*/
select * from table
/
/*Query 3*/
select col form tab2
;
/*Query 4*/
select col2 from tab3 /*this is a multi line comment*/
/
期望的结果
[1]: /*Query 1*/
SELECT
*
FROM tab t
WHERE (t.col1 in (1, 3)
and t.col2 IN (1,5,8,9,10,11,20,21,
22,23,24,/*Reaffirmed*/
25,26,27,28,29,30,
35,/*carnival*/
75,76,77,78,79,
80,81,82, /*Damark accounts*/
84,85,87,88,90))
[2]:/*Query 2*/
select * from table
[3]: /*Query 3*/
select col form tab2
[4]:/*Query 4*/
select col2 from tab3 /*this is a multi line comment*/
其中一半已经可以通过上一篇文章中向我提出的建议来实现(link a start),但是当在查询中引入注释语法(/*)并且每个查询也可以用正斜杠(/)分隔时,表达式不起作用。