create table T_VALUES (
VAL varchar2(20)
);
insert into T_VALUES values ('A');
insert into T_VALUES values ('B');
insert into T_VALUES values ('C');
insert into T_VALUES values ('D');
create table T_JOBS (
JOB_ID int,
STR_LIST varchar2(50)
);
insert into T_JOBS values (1, 'r, e, ''Hello'' A w: B, xyz');
insert into T_JOBS values (2, 'ok, D ');
select
job_id,
val
from
T_VALUES
natural join (
select
job_id,
regexp_substr(str_list, '[^ ,]+', 1, occ) as val
from
T_JOBS
cross join (
select level as occ from dual
connect by level <= (select max(length(str_list)) from T_JOBS)
)
)
order by 1, 2
fiddle
編輯:
改進版(使用Ben的想法)
create table T_VALUES (
VAL varchar2(20)
);
insert into T_VALUES values ('A');
insert into T_VALUES values ('B');
insert into T_VALUES values ('C');
insert into T_VALUES values ('D');
create table T_JOBS (
JOB_ID int,
STR_LIST varchar2(50)
);
insert into T_JOBS values (1, 'junk, values=A:NotA:B:r:e, more_junk');
insert into T_JOBS values (2, 'ok, values=D ');
create type nt_str as table of varchar2(50);
select
j.job_id,
v.val
from
T_JOBS j,
table(
cast(
multiset(
select
regexp_substr(
regexp_substr(j.str_list, 'values=([^, ]+)', 1, 1, 'i', 1),
'[^:]+', 1, level)
from dual
connect by
regexp_substr(
regexp_substr(j.str_list, 'values=([^, ]+)', 1, 1, 'i', 1),
'[^:]+', 1, level) is not null
) as nt_str
)
) t
join T_VALUES v
on v.val = t.column_value
order by 1, 2
one more fiddle
不完全理解您的請求。上述數據有什麼期望的結果? – sgeddes 2013-02-23 20:35:46
第三個表存在來自計劃作業的事務記錄。每條記錄都有一個與之相關的值(A,B,C或D)。用戶可以隨時調整調度程序,因此STRINGS_TO_SEARCH可以更改。我計劃使用查詢來識別已安排用於特定作業的特定交易記錄。 – Nitax 2013-02-23 21:00:24
鑑於你的問題中的數據,你想要什麼結果?搜索字符串是如何用逗號或空格分隔的? – 2013-02-23 21:10:57