Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

Oracle ट्रिगर जो मासिक आधार पर बाधा की जाँच करता है

ट्रिगर का उपयोग करना, जबकि यह काम करता प्रतीत होता है, इसे करने का एक खतरनाक तरीका है, क्योंकि समानांतर में चलने वाले सत्रों में इनप्रोग्रेस सत्र से सम्मिलित डेटा नहीं दिखाई देगा। आप इसे एक भौतिक दृश्य के माध्यम से कर सकते हैं:

SQL> create table rent (id number primary key, member varchar2(30), book varchar2(20), date_rented date);

Table created.

SQL> create index rent_ix1 on rent ( member, date_rented);

Index created.

SQL> create materialized view log on rent with rowid(member,date_rented)
  2  including new values;

Materialized view log created.

SQL> create materialized view rent_month_check
  2  refresh fast on commit
  3  as
  4  select trunc(date_rented, 'mm') month, member, count(*) rentals
  5    from rent
  6   group by trunc(date_rented, 'mm'), member;

Materialized view created.

SQL> alter table rent_month_check
  2  add constraint rent_month_check_ck1 check (rentals <= 4);

Table altered.

SQL> insert into rent values(1, 'DazzaL', 'crime', sysdate);

1 row created.

SQL> commit;

Commit complete.

SQL> insert into rent values(2, 'DazzaL', 'mystery', sysdate+1);

1 row created.

SQL> commit;

Commit complete.

SQL> insert into rent values(3, 'DazzaL', 'fantasy', sysdate+2);

1 row created.

SQL> commit;

Commit complete.

SQL> insert into rent values(4, 'DazzaL', 'politics', sysdate+3);

1 row created.

SQL> commit;

Commit complete.

SQL> insert into rent values(5, 'DazzaL', 'thriller', sysdate+4);

1 row created.

SQL> commit;
commit
*
ERROR at line 1:
ORA-12008: error in materialized view refresh path
ORA-02290: check constraint (TEST.RENT_MONTH_CHECK_CK1) violated


SQL> select * from rent_month_check;

MONTH     MEMBER                            RENTALS
--------- ------------------------------ ----------
01-NOV-12 DazzaL                                  4


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle SQL डेवलपर का उपयोग करके CSV को तालिका कैसे निर्यात करें?

  2. ओरेकल में राउनम की तरह मैसकल में पंक्ति संख्या प्राप्त करने का कोई तरीका है?

  3. मेमोरी में पूरी फाइल लोड किए बिना बीएलओबी (ओरेकल) में एक बड़ी फाइल कैसे डालें?

  4. Oracle फ़ंक्शन से रेफ कर्सर लौटाना

  5. ORA-01658:टेबलस्पेस में सेगमेंट के लिए प्रारंभिक सीमा बनाने में असमर्थ TS_DATA