Oracle
 sql >> база данни >  >> RDS >> Oracle

Свържете няколко реда в една колона с помощта на функция в Oracle с 3 свързани таблици

Трябва да промените функцията си, за да прилича на:

CREATE OR REPLACE FUNCTION f_test(IN_ID IN TABLE_C.a_id%TYPE) 
RETURN VARCHAR2 
IS

  l_text  VARCHAR2(32767) := NULL;

BEGIN

  FOR cur_rec IN (SELECT b.b_name 
                    FROM TABLE_B b
                    JOIN TABLE_C c ON c.b_id = b.b_id
                   WHERE c.a_id = IN_ID) LOOP
    l_text := l_text || ',' || cur_rec.b_id;
  END LOOP;

  RETURN LTRIM(l_text, ',');

END;

След това можете да използвате:

SELECT a.a_name, 
       f_test(a.a_id)
  FROM TABLE_A a


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Преброяване на CLOB дубликати в голяма таблица на Oracle

  2. Сортирайте знаците във varchar2 по азбучен ред

  3. ORA-28000:акаунтът е заключен Грешка става често

  4. Има ли някакъв начин пула за връзки на JBoss да се свърже отново с Oracle, когато връзките се развалят?

  5. Преобразуване на Unixtime в Datetime SQL (Oracle)