首页 > 解决方案 > 如何在 Oracle 中更改视图的列大小

问题描述

我正在尝试使用我们用于表的相同命令来更改视图的列大小,例如:

alter table 
STUDENT
modify (
    ROLL_NO VARCHAR2(80)
);

但它的投掷错误

SQL 错误:ORA-00942:表或视图不存在

那么我们如何改变视图的列大小呢?

标签: sqloracleviewaltercolumn-sizing

解决方案


视图只是保存查询并从基础基表“继承”列类型。因此,如果您需要更改元数据,您应该更改视图定义:

ALTER VIEW view_students
AS
SELECT CAST(roll_no AS VARCHAR2(80)) AS roll_no,
     ...
FROM tab_students;

如果要更改数据类型以存储更长的字符串,则需要找到基表并更改它:

ALTER VIEW tab_students
MODIFY (ROLL_NO VARCHAR2(80));

推荐阅读