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

时间:2018-09-05 16:50:37

标签: sql oracle view alter column-sizing

我正在尝试使用与表类似的命令来更改视图的列大小:

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

但是它的抛出错误

  

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

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

2 个答案:

答案 0 :(得分:3)

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

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 :(得分:0)

这是我遵循的过程:

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

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

2-在上面的查询中,您将找到一个表,在该表中您可以在列名“ REFERENCED_NAME”下找到基表。

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

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