扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
从Oracle9i开始,Oracle允许对于视图(view)进行主键、唯一键、外键约束的声名。NOT NULL约束可以从基表继承,所以不允许显示声明。
由于视图约束仅仅是声明而已,所以其状态只能是DISABLE NOVALIDATE。
以下是一个简单范例说明:
SQL> CREATE VIEW d10_emp View created. SQL> select * from d10_emp; EMPNO ENAME JOB DEPTNO SQL> select CONSTRAINT_NAME,TABLE_NAME,CONSTRAINT_TYPE from user_constraints CONSTRAINT_NAME TABLE_NAME C |
由于此约束仅仅为"约束声明",所以不具有实际约束力:
SQL> insert into d10_emp values(7777,'EYGLE','MANAGER',10); 1 row created. SQL> insert into d10_emp values(8888,'EYGLE','MANAGER',10); 1 row created. SQL> select * from d10_emp; EMPNO ENAME JOB DEPTNO |
濠碘€冲€归悘澶愬箖閵娾晜濮滈悽顖涚摃閹烩晠宕氶崶鈺傜暠闁诡垰鍘栫花锛勬喆椤ゅ弧濡澘妫楅悡娆撳嫉閳ь剟寮0渚€鐛撻柛婵呮缁楀矂骞庨埀顒勫嫉椤栨瑤绻嗛柟顓у灲缁辨繈鏌囬敐鍕杽閻犱降鍨藉Σ鍕嚊閹跺鈧﹦绱旈幋鐐参楅柡鍫灦閸嬫牗绂掔捄铏规闁哄嫷鍨遍崑宥夋儍閸曨剚浠樺ù锝嗗▕閳ь剚鏌ㄧ欢鐐寸▕鐎b晝顏遍柕鍡嫹