sql - 如何在 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));
推荐阅读
- fine-uploader - FineUploader 5.14.0 - setParams 不适用于大文件
- caching - 虚拟索引物理标记缓存如何解决同音异义问题?
- django - 如何在 Wagtail CMS 中添加对 ImageChooserBlock 的矢量图像支持?
- java - 在 Tomcat 中为 Spring Boot 应用程序访问 externalize application.properties?
- keras - 在 R 中部署闪亮的应用程序时出现问题。使用带有网状结构的虚拟环境在应用程序中运行 python 代码。错误——虚拟环境:权限被拒绝
- python - Tensorflow 交错输入管道变得非常慢
- excel - Excel公式静态值增量
- azure - Azure 表存储数据建模注意事项
- adfs - 在已加入域的服务器中启用 adfs
- c# - 如何在 c# 中使用模拟/服务帐户(如在 Exchange api 中)读取同一域中所有用户的 gmail