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

Продължаващи вмъквания в Oracle, когато се повдигне изключение

Ако обемите на данните бяха по-големи, обработката ред по ред в PL/SQL вероятно щеше да е твърде бавна. При тези обстоятелства можете да използвате регистриране на грешки в DML, описано тук

CREATE TABLE raises (emp_id NUMBER, sal NUMBER 
   CONSTRAINT check_sal CHECK(sal > 8000));

EXECUTE DBMS_ERRLOG.CREATE_ERROR_LOG('raises', 'errlog');

INSERT INTO raises
   SELECT employee_id, salary*1.1 FROM employees
   WHERE commission_pct > .2
   LOG ERRORS INTO errlog ('my_bad') REJECT LIMIT 10;

SELECT ORA_ERR_MESG$, ORA_ERR_TAG$, emp_id, sal FROM errlog;

ORA_ERR_MESG$               ORA_ERR_TAG$         EMP_ID SAL
--------------------------- -------------------- ------ -------
ORA-02290: check constraint my_bad               161    7700
 (HR.SYS_C004266) violated


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Симулиран OLAP

  2. SQLT в 12c не може да събира статистически данни

  3. Намерете всички нечислови стойности в колона в Oracle

  4. Как мога да дам псевдоним на таблица в Oracle?

  5. Как да премахнете правилната подплата в името на деня в Oracle