如何更改 Oracle 中视图的列大小
How to alter column size of a view in Oracle
我正在尝试使用我们用于 table 的相同命令来更改视图的列大小,例如:
alter table
STUDENT
modify (
ROLL_NO VARCHAR2(80)
);
但是它抛出错误
SQL Error: ORA-00942: table or view does not exist
那么我们如何改变视图的列大小呢?
视图只是保存的查询和来自底层基础 table 的 "inherits" 列类型。因此,如果您需要更改元数据,您应该更改视图定义:
ALTER VIEW view_students
AS
SELECT CAST(roll_no AS VARCHAR2(80)) AS roll_no,
...
FROM tab_students;
如果您想要更改数据类型以存储更长的字符串,那么您需要找到基数 table 并改为更改它:
ALTER VIEW tab_students
MODIFY (ROLL_NO VARCHAR2(80));
这是我遵循的程序:
1- 首先通过 运行 以下查询
找到该视图的基础 table
SELECT * FROM DBA_DEPENDENCIES
WHERE OWNER = '<scheman_name>'
AND NAME = '<view_name>'
AND TYPE = 'VIEW';
2- 以上查询将为您提供一个 table,您将在其中找到列名 'REFERENCED_NAME'.
下的基数 table
3- 现在更改该基数的列大小 table。
注意:视图可以由 1 个或多个 table 组成,因此您需要更改所有这些基础 table 的列大小。
我正在尝试使用我们用于 table 的相同命令来更改视图的列大小,例如:
alter table
STUDENT
modify (
ROLL_NO VARCHAR2(80)
);
但是它抛出错误
SQL Error: ORA-00942: table or view does not exist
那么我们如何改变视图的列大小呢?
视图只是保存的查询和来自底层基础 table 的 "inherits" 列类型。因此,如果您需要更改元数据,您应该更改视图定义:
ALTER VIEW view_students
AS
SELECT CAST(roll_no AS VARCHAR2(80)) AS roll_no,
...
FROM tab_students;
如果您想要更改数据类型以存储更长的字符串,那么您需要找到基数 table 并改为更改它:
ALTER VIEW tab_students
MODIFY (ROLL_NO VARCHAR2(80));
这是我遵循的程序:
1- 首先通过 运行 以下查询
找到该视图的基础 tableSELECT * FROM DBA_DEPENDENCIES
WHERE OWNER = '<scheman_name>'
AND NAME = '<view_name>'
AND TYPE = 'VIEW';
2- 以上查询将为您提供一个 table,您将在其中找到列名 'REFERENCED_NAME'.
下的基数 table3- 现在更改该基数的列大小 table。
注意:视图可以由 1 个或多个 table 组成,因此您需要更改所有这些基础 table 的列大小。