如何在 Oracle 中更改视图的列大小



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

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

但它的投掷错误

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

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

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

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));

这是我遵循的程序:

1-首先通过运行以下查询查找该视图的基表

SELECT * FROM DBA_DEPENDENCIES
WHERE OWNER = '<scheman_name>'
AND NAME = '<view_name>'
AND TYPE = 'VIEW';

2-上面的查询将为您提供一个表,您可以在其中找到列名"REFERENCED_NAME"下的基表。

3-现在更改该基表的列大小。

注意: 视图可以由 1 个或多个表组成,因此您需要更改所有这些基表的列大小。

相关内容

  • 没有找到相关文章

最新更新