Oracle
 sql >> Teknologi Basis Data >  >> RDS >> Oracle

Variabel tabel diisi hanya dengan satu nilai

Gunakan BULK COLLECT dan FORALL untuk sisipan massal dan kinerja yang lebih baik. UNTUK pernyataan akan memungkinkan DML dijalankan untuk setiap baris dalam koleksi tanpa memerlukan sakelar konteks setiap kali, sehingga meningkatkan kinerja secara keseluruhan.

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. Terapkan filter di Oracle View

  2. Dapatkan ID terakhir pada baris yang dimasukkan di Oracle DB

  3. Oracle SQL:Kolom tidak diizinkan

  4. PL/SQL daftar dipisahkan koma; hapus dups dan masukkan ke dalam array

  5. Enkripsi kata sandi di R - untuk terhubung ke Oracle DB menggunakan RODBC