Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Zmienna tabeli jest wypełniona tylko jedną wartością

Użyj BULK COLLECT i FORALL dla masowych wkładek i lepszej wydajności. FORALL instrukcja umożliwi uruchomienie DML dla każdego wiersza w kolekcji bez konieczności każdorazowego przełączania kontekstu, poprawiając w ten sposób ogólną wydajność.

CREATE OR REPLACE PROCEDURE get_attributes (
    p_auth_use_id  IN   NUMBER,
    p_category_id  IN   NUMBER,
    p_version_id   IN   NUMBER,
    p_result       OUT  types.cursor_type
) IS
    v_numbers sys.odcinumberlist := NULL;
BEGIN 
    SELECT s.id
    BULK COLLECT --> Bulk collect all values
    INTO v_numbers
    FROM inv_srv s
        start with s.parent_srv_id in (
          SELECT ID FROM INV_SRV 
          WHERE SRV_CATEGORY_ID IN 
            (
                SELECT id
                FROM   inv_srv_category
                START WITH parent_category_id = P_CATEGORY_ID
                CONNECT BY PRIOR id = parent_category_id
            ) 
            OR SRV_CATEGORY_ID = P_CATEGORY_ID)
        connect by prior s.id = s.parent_srv_id;

        FORALL i IN 1..v_numbers.COUNT   
        INSERT INTO your_table VALUES v_numbers ( i ); --> Bulk insert

END;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Numer zwrotu z wyciągu Oracle Select po dacie parsowania

  2. Czy istnieje aparat bazy danych, który pozwala na kwerendalne ograniczenie pola określone przez RegEx?

  3. ciąg połączenia java do obsługi funkcji Oracle TAF

  4. SQL Server / Oracle :Prywatne tabele tymczasowe

  5. SQL z rangą i partycją