Dan*_*ish 2 sql oracle view alter column-sizing
我正在尝试使用与表相同的命令来更改视图的列大小,例如:
alter table
STUDENT
modify (
ROLL_NO VARCHAR2(80)
);
Run Code Online (Sandbox Code Playgroud)
但它的抛出错误
SQL 错误:ORA-00942:表或视图不存在
那么我们如何改变视图的列大小呢?
视图只是保存的查询并从底层基表“继承”列类型。因此,如果您需要更改元数据,您应该更改视图定义:
ALTER VIEW view_students
AS
SELECT CAST(roll_no AS VARCHAR2(80)) AS roll_no,
...
FROM tab_students;
Run Code Online (Sandbox Code Playgroud)
如果您想更改数据类型以存储更长的字符串,那么您需要找到基表并更改它:
ALTER VIEW tab_students
MODIFY (ROLL_NO VARCHAR2(80));
Run Code Online (Sandbox Code Playgroud)