文档解释
ORA-22906: cannot perform DML on expression or on nested table view column
Cause: Attempted to perform a DML on an expression or on a nested table view column where a nested table column of a base table is expected.
Action: Only nested table column of a base table is allowed in the DML.
ORA-22906: cannot perform DML on expression or on nested table view column
这个错误提示表示,当尝试在数据库表的视图或者表达式上做Data Manipulation Language(DML)操作,数据库处理器检测到为这种操作没有指定有效的视图表,这次操作将会失败。
该错误一般发生的原因:
1. 前面的查询语句中有错误或者执行效率低
2. 使用不特定表的上下文非常高,有可能把多张表合并
3. 使用了错误语法
4. Nested table容易出现这类错误
一般处理方法及步骤
1. 检查当前执行的语句,确保语法正确
2. 检查使用的Nested table,确保支持DML操作
3. 根据数据库版本更新语句,避免不兼容的情况
4. 检查语句效率,尝试改善查询语句执行效率