1

选择查询时,我需要从 Table2 的值中替换 Table1 的字段值。

例如:

表格1:

Org                  Permission
--------------------------------------
Company1             1,3,7
Company2             1,3,8

表2:

Permission          Permission
--------------------------------------
1                   Read
3                   Write
7                   Execute
8                   Delete

我需要这样:

Org                  Permission
--------------------------------------
Company1             Read,Write,Execute
Company2             Read,Write,Delete
4

3 回答 3

1

如果您不想更新现有表并且只想选择数据,那么您可以使用这个有点费力的查询。

http://sqlfiddle.com/#!4/22909/4

WITH changed_table AS
     (SELECT val1, EXTRACTVALUE (x.COLUMN_VALUE, 'e') val2new
        FROM (SELECT val1, val2 xml_str
                FROM table1),
             TABLE (XMLSEQUENCE (XMLTYPE (   '<e><e>'
                                          || REPLACE (xml_str, ',', '</e><e>')
                                          || '</e></e>'
                                         ).EXTRACT ('e/e')
                                )
                   ) x)
SELECT ct.val1, listagg(table2.val2,',') within group (order by table2.val2) val2
  FROM changed_table ct, table2 table2
 WHERE ct.val2new = table2.val1
group by ct.val1;

我使用 XMLTYPE 将逗号分隔的数字分隔为行。然后将行与第二个表连接以获得描述,最后使用 LISTAGG 函数形成逗号分隔的字符串。不知道这个查询效率如何。我同意马克班尼斯特的评论。

于 2013-05-23T11:38:43.193 回答
0

这里为这种替换提供了一个很棒的解决方案。

它只是创建了一个 multiple_replace 函数:

CREATE TYPE t_text IS TABLE OF VARCHAR2(256);

CREATE FUNCTION multiple_replace(
  in_text IN VARCHAR2, in_old IN t_text, in_new IN t_text
)
  RETURN VARCHAR2
AS
  v_result VARCHAR2(32767);
BEGIN
  IF( in_old.COUNT <> in_new.COUNT ) THEN
    RETURN in_text;
  END IF;
  v_result := in_text;
  FOR i IN 1 .. in_old.COUNT LOOP
    v_result := REPLACE( v_result, in_old(i), in_new(i) );
  END LOOP;
  RETURN v_result;
END;

然后您可以使用此查询来替换:

UPDATE Table1
SET permission_id = multiple_replace(Permission, (select distinct Permission from table2), 
        (select distinct Permission_name from table2));
于 2013-05-23T10:52:39.610 回答
0

在 Oracle 中,您可以运行此 PL/SQL 块,它将完成所有工作:

begin
  for x in (
    select permission, descr from table2
  ) loop
    update table1 set permission = replace(permission, x.permission, x.descr);
  end loop;
  commit;
end
/

我使用这个脚本来创建一个模式:

create table table1(
  org varchar2(100),
  permission varchar2(1000)
);

create table table2(
  permission varchar2(100),
  descr varchar2(1000)
);

insert into table1(org, permission) values ('Company1', '1,3,7');
insert into table1(org, permission) values ('Company2', '1,3,8');
insert into table2(permission, descr) values ('1', 'Read');
insert into table2(permission, descr) values ('7', 'Execute');
insert into table2(permission, descr) values ('8', 'Delete');
于 2013-05-23T10:28:16.033 回答