oracle view

Jun 07, 2016 pm 03:44 PM
oracle view 优点 用户 视图 限制

视图 视图具有以下优点 1、限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽创建视图所基于的底层基表。 2、可以将复杂查询编写为视图。这样可以对最终用户屏蔽一定的复杂性。 3、限制某个视图只能访问基表中的部分数据,这样可以实现另外一层安全性

 视图

视图具有以下优点

   1、限制用户只能通过视图检索数据。这样就可以对最终用户屏蔽创建视图所基于的底层基表。

   2、可以将复杂查询编写为视图。这样可以对最终用户屏蔽一定的复杂性。

   3、限制某个视图只能访问基表中的部分数据,这样可以实现另外一层安全性,并且可以对最终用户屏蔽部分行。

 

        CREATE [OR REPLACE] VIEW [ { FORCE | NOFORCE }] view_name

       [ (alias_name[,alias_name ...])]  AS subquery

       [ WITH { CHECK OPTION | READ ONLY } CONSTRAINT constraint_name];

       其中OR REPLACE 说明如果视图已经存在,就替换现有视图。

     FROCE 说明即使基表不存在,也要创建视图,

    NOFORCE 说明如果基表不存在,就不创建视图,NOFORCE是默认值。

    subquery指定一个子查询。

    WIHT CHECK OPTION 说明只有子查询检索的行才能被插入,修改、删除。默认情况下,在插入、修改、删除行之前不会检索这些行是否被子查询检索

     WIHT READ ONLY 说明只能对基表中的行进行只读访问。

--简单视图

CREATEVIEW v_cheap_products1

AS

SELECT *

FROM products

WHERE price15;

      

CREATE VIEW  v_employees

AS

SELECTemployee_id,manager_id,first_name,last_name,title

FROM employees;

 

--对视图执行insert操作

INSERTINTO v_cheap_products1 (

product_id,product_type_id,name,price

       ) values (

       12,1,'Western Front',13.50

);

/**注意:只能对简单视图执行DML操作;复杂视图不支持DML操作.*****************/

--由于v_cheap_products没有使用WITH CHECK OPTION,因此可以插入、修改、删除那些子查询不能检索的行。

INSERTINTO v_cheap_products1 (

       product_id,product_type_id,name,price

 ) values (

14,1,'Eastern Front',16.5

 );

--以上插入了子查询不能检索的行,因此以下检索不到数据

SELECT *

FROMv_cheap_products

WHEREproduct_id =14;

--创建具有CHECK OPTION约束的视图:通过为视图添加CHECK OPTION约束,可以指定对视图执行DML操作必须满足子查询的条件

CREATEVIEW v_cheap_products2

AS

SELECT *

FROM products

WHERE price

WITH  CHECK  OPTION    CONSTRAINT cheap_products_v2_price;

 

--插入以下数据会报错

INSERTINTOv_cheap_products (

product_id,product_type_id,name,price

       ) values (

       14,1,'Eastern Front',16.5

       ); 

      

--创建只读视图:对于只读视图,不能对其执行DML操作

CREATEVIEW v_cheap_products3

AS

SELECT *

FROM products

WHERE price

WITH    READ   ONLY   CONSTRAINT cheap_products_v3_price;

 

--创建复杂视图

CREATEVIEWv_products_and _types

AS

SELECT p.name product_name,pt.nameproduct_type_name,p.price

FROM products p FULL   OUTER   JOIN  product_types  pt

USING(product_type_id)

      

CREATEVIEWv_employee_salary_grades

AS

SELECT  e.first_name,  e.last_name,  e.title,  e.salary, sa.salary_grade_id

FROM  employees e INNER   JOINsalary_grades   sg   ON   e.salary    BETWEEN   sg.low_salary  AND  sg.high_salary;

      

--下面这个例子创建视图v_product_average,子查询使用

/*WHERE 子句对products表中的行进行过滤,只保留那些价格低于$15的记录

       GROUP BY子句对剩余的行根据product_type_id列进行分组

       HAVING 子句对分组进行过滤,只保留那些平均价格低于$13的分组*/

CREATEVIEWv_product_average

AS

SELECTproduct_type_id,AVG(price) average_price

FROM products

WHERE price

GROUPBYproduct_type_id

HAVINGAVG(price) >13;

 

--修改视图CREATE OR REPLACE,使用ALTER VIEW可以修改视图的约束

CREATE OR REPLACE   VIEW   v_product_average

AS

SELECTproduct_type_id,AVG(price) average_price

FROM products

WHERE price

GROUPBYproduct_type_id

HAVINGAVG(price) >11;

 

--获取视图定义信息describe

DESC v_cheap_products3

--获取用户所创建的视图信息

select * from   user_views;

--获取可以访问的视图信息

select * from   all_views;

--获取有关视图的约束信息

select  constraint_name,constraint_type,status

from user_constraints

where  table_name   in ('V_CHEAP_PRODUCTS1','V_CHEAP_PRODUCTS2');

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
威尔R.E.P.O.有交叉游戏吗?
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

oracle如何查表空间大小 oracle如何查表空间大小 Apr 11, 2025 pm 08:15 PM

要查询 Oracle 表空间大小,请遵循以下步骤:确定表空间名称,方法是运行查询:SELECT tablespace_name FROM dba_tablespaces;查询表空间大小,方法是运行查询:SELECT sum(bytes) AS total_size, sum(bytes_free) AS available_space, sum(bytes) - sum(bytes_free) AS used_space FROM dba_data_files WHERE tablespace_

oracle如何获取时间 oracle如何获取时间 Apr 11, 2025 pm 08:09 PM

在 Oracle 中获取时间有以下方法:CURRENT_TIMESTAMP:返回当前系统时间,精确到秒。SYSTIMESTAMP:比 CURRENT_TIMESTAMP 更准确,精确到纳秒。SYSDATE:返回当前系统日期,不含时间部分。TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS'): 将当前系统日期和时间转换为特定格式。EXTRACT:从时间值中提取特定部分,如年份、月份或小时。

oracle如何查看实例名 oracle如何查看实例名 Apr 11, 2025 pm 08:18 PM

在 Oracle 中查看实例名的方法有三种:命令行中使用 "sqlplus" 和 "select instance_name from v$instance;" 命令。在 SQL*Plus 中使用 "show instance_name;" 命令。通过操作系统的任务管理器、Oracle Enterprise Manager 或检查环境变量 (Linux 上的 ORACLE_SID)。

oracle视图如何加密 oracle视图如何加密 Apr 11, 2025 pm 08:30 PM

Oracle 视图加密允许您加密视图中的数据,从而增强敏感信息安全性。步骤包括:1) 创建主加密密钥 (MEk);2) 创建加密视图,指定要加密的视图和 MEk;3) 授权用户访问加密视图。加密视图工作原理:当用户查询加密视图时,Oracle 使用 MEk 解密数据,确保只有授权用户可以访问可读数据。

Oracle安装失败如何卸载 Oracle安装失败如何卸载 Apr 11, 2025 pm 08:24 PM

Oracle 安装失败的卸载方法:关闭 Oracle 服务,删除 Oracle 程序文件和注册表项,卸载 Oracle 环境变量,重新启动计算机。若卸载失败,可使用 Oracle 通用卸载工具手动卸载。

oracle无效数字如何排查 oracle无效数字如何排查 Apr 11, 2025 pm 08:27 PM

Oracle 无效数字错误可能由数据类型不匹配、数字溢出、数据转换错误或数据损坏引起。排查步骤包括检查数据类型、检测数字溢出、检查数据转换、排查数据损坏,并探索其他可能的解决方案,如配置 NLS_NUMERIC_CHARACTERS 参数和启用数据验证日志记录。

oracle如何设置用户 oracle如何设置用户 Apr 11, 2025 pm 08:21 PM

在 Oracle 中创建用户需遵循以下步骤:使用 CREATE USER 语句创建新用户。使用 GRANT 语句授予必要权限。可选:使用 RESOURCE 语句设置配额。配置其他选项,如默认角色和临时表空间。

oracle游标关闭怎么解决 oracle游标关闭怎么解决 Apr 11, 2025 pm 10:18 PM

解决 Oracle 游标关闭问题的方法包括:使用 CLOSE 语句显式关闭游标。在 FOR UPDATE 子句中声明游标,使其在作用域结束后自动关闭。在 USING 子句中声明游标,使其在关联的 PL/SQL 变量关闭时自动关闭。使用异常处理确保在任何异常情况下关闭游标。使用连接池自动关闭游标。禁用自动提交,延迟游标关闭。

See all articles