Oracle
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Oracle

Biến bảng chỉ được điền bằng một giá trị

Sử dụng BULK COLLECTFORALL để chèn số lượng lớn và hiệu suất tốt hơn. FORALL câu lệnh sẽ cho phép chạy DML cho mỗi hàng trong bộ sưu tập mà không yêu cầu chuyển đổi ngữ cảnh mỗi lần, do đó cải thiện hiệu suất tổng thể.

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. câu hỏi phỏng vấn oracle PLSQL

  2. Chỉ một hoạt động cho mỗi ràng buộc mối quan hệ

  3. SQL - Mã định danh không hợp lệ, nhưng ở đâu?

  4. Oracle JDBC PreparedStatement bỏ qua khoảng trống theo dõi

  5. 7 cách để kiểm tra phiên bản Oracle của bạn