1.测试表表结构如下
data:image/s3,"s3://crabby-images/cf09d/cf09db237956543dd8e950971e621b520faa8f4d" alt=""
2.表中数据如下
3.开始实验视图使用中的一些注意事项
实验一:
data:image/s3,"s3://crabby-images/52766/52766fcacac82395b6fa5069e60c12fb91d6fc5d" alt=""
data:image/s3,"s3://crabby-images/64e53/64e53e60c68fb561529fe9cb543f32ebe3082e7c" alt=""
结论:建立视图添加with cheak option 的约束后,对视图进行dml操作时,会在where后面的条件记性校验
实验二:
data:image/s3,"s3://crabby-images/fa5b3/fa5b3e116cbef84bb5f283f4b5ab950cc92488d9" alt=""
data:image/s3,"s3://crabby-images/b558f/b558f21fe176d408d5daa2054a5bf34657a7c7cf" alt=""
结论:
基表中含有非空列,所建的视图不包含此非空列,无法对此视图进行插入操作
实验三:
data:image/s3,"s3://crabby-images/cd7c7/cd7c7a95338dfa56fb48bf9ebac0dbe01ac7520a" alt=""
结论:建立视图时,不能出现含有分组函数
总结以上:
Rules for Performing DML Operations on a View
You cannot add data through a view if the view includes:
Group functions
A GROUP BY clause
The DISTINCT keyword
The pseudo column ROWNUM keyword
Columns defined by expressions
NOT NULL columns in the base tables that are not selected by the view
(以上内容出自官网文档)