Oracle中的视图

这篇具有很好参考价值的文章主要介绍了Oracle中的视图。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1- 什么是视图

视图是一个虚拟表

视图是由sql查询语句产生的

视图真实存在 但是不存储数据

视图中的数据 只是对 基表(源数据表) 中的数据的引用

总的来说 视图可以简化数据

用户,订单,物流 三个表进行关联 吧很复杂的sql查询语句存储成一个视图 

获取结果就可以直接查询视图 不用再重复的进行sql查询

并且提供一定的安全性 以及 向后兼容性

视图你可以理解为   从原来的很多表中 select出你需要的几个字段信息进行查询 并且形成视图

无需重复查询,通过原表select出视图 。并且可以通过原表同步数据到t2表格

如果删除原表 则视图也无法查询

语法格式:

create [or replace] [force] view view_name
as 
subquery
[with check option ]
[with read only]

  • or replace

    • 替换已存在的视图

  • force

    • 强制创建视图(可以给不存在的数据表创建视图)

  • with check option

    • 不能修改视图形成字段的数据

  • with read only

    • 只读不能进行数据修改

with check option的作用

Oracle中的视图,数据库,oracle,sql

  • 简单视图 中的任意数据都可以进行任意操作

  • with check option 只要不影响我们的非视图数据就可以操作

with read only

视图不能进行任何的dml操作(增删改)

or replace

替换原有的视图

force

  • 作用

    • 创建一个没有源数据表的视图

  • 删除视图

    • drop view 视图名

2-复杂视图

  • 定义

    • 多表 聚合函数 子查询 等

  • 注意

    • 不要dml操作 很容易出错

3-物化视图

  • 什么是物化视图

    • 视图 是不会存储数据的

    • 物化视图 是真实存储数据

  • 为什么要物化视图

    • 加快查询速度

    • 数据量变大 视图查询速度比较慢

    • 物化视图 查询速度比较快

    • meger on readOracle中的视图,数据库,oracle,sql

  • meger on write  <<加快数据同步>>

  • Oracle中的视图,数据库,oracle,sql

语法格式

create materialized view view_name
[build immediate  |  build deferred ]
refresh [fast|complete|force]
[
on  [commit  |  demand ]  |  start  with  (start_time)  next
(next_time)
]
as
subquery

  • materialized view

    • 物化视图

  • build immediate(默认)

    • 创建视图后 立马生成数据

  • build deferred

    • 创建视图后 等待刷新生成数据

  • refresh : 数据刷新

    • fast : 增量更新

    • complete : 全量更新

    • force (默认方式)

      • 尝试使用fast更新

      • 再去使用全量更新

    • on (确定更新时机)

      • commit : 基表只要commit就会开始更新

      • demand : 手动方式(刷新) (默认的)

物化视图的增量更新

Oracle中的视图,数据库,oracle,sql

增量更新语法

  • 增量更新的物化视图

    • 创建基表的物化视图日志

    • 产生物化视图的 sql 必须包含rowid

创建日志

创建日志
create materialized view log on T_ADDRESS with rowid;
物化视图的sql必须包含rowid
select
        T_ADDRESS.ROWID as addr_rowid,
        T_AREA.ROWID as area_rowid,
        T_ADDRESS.ID, T_ADDRESS.NAME, T_AREA.NAME area
from T_ADDRESS
inner join T_AREA on T_ADDRESS.AREAID = T_AREA.ID;

4-序列

什么是序列

  • 一个可以产生 唯一数字

    • 设置起始位置

    • 设置增长数量

    • 最大值

    • 最小值

    • 循环

序列语法格式

CREATE SEQUENCE sequence  //创建序列名称

[INCREMENT BY n]  //递增的序列值是 n 如果 n 是正数就递增,如果是负数就递减 默认是 1

[START WITH n]     //开始的值,递增默认是 minvalue 递减是 maxvalue

[{MAXVALUE n | NOMAXVALUE}] //最大值
[{MINVALUE n | NOMINVALUE}] //最小值

[{CYCLE | NOCYCLE}] //CYCLE和NOCYCLE 表示当序列的值达到限制值后是否循环。CYCLE代表循环即到达例如最大值后重新从最小值开始

[{CACHE n | NOCACHE}];//定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。

注意点

  • 起始值是不能小于最小值的

  • 如果没有循环 能取到值 是不能超过最大值的

  • 如果有循环 起始从最小值开始

  • cache默认是为20的 循环值是要大于这个值的

5-同义词

  • 对象的别名

    • 对象 : 表 序列 视图

  • 作用

    • 私有

      • 只能是创建这个同义词的用户使用

    • 共有

      • 所有的用户都可以使用

    • 给对象起别名 设置为公共的

      • 所有人都可以用这个同义词 所有人都不知道原始表名 表的用户

语法格式  

create [public] SYNONYM synooym for object;

  • 不加public就是私有的

  • 加public就是共有的文章来源地址https://www.toymoban.com/news/detail-858553.html

到了这里,关于Oracle中的视图的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Oracle数据库SQL Plus基础命令

    1.使用SQL*Plus登录Oracle数据库 开始 -- 所有程序 -- Oracle -- 应用程序开发 -- SQL Plus cmd窗口下输入:sqlplus 用户名/口令@主机字符串 2.使用CMD命令登录Oracle数据库 开始 -- 所有程序 -- 附件 -- 命令提示符 使用命令行登陆的连接命令格式为:sqlplus/@net_service_name username为用户名;passw

    2024年02月06日
    浏览(20)
  • Sql server和Oracle默认数据库

            SQL Server 和 Oracle 都有自带的一些默认数据库,保存了不同的系统信息和配置数据。         SQL Server 上的默认数据库:          master :SQL Server 引擎的系统级目录,存储了 所有系统层级的信息和元数据 ,例如登录账号信息。         tempdb:存储各种系

    2024年02月09日
    浏览(18)
  • oracle如何定期备份数据库sql文件

    Oracle数据库可以使用以下方法定期备份数据库的SQL文件: 使用Oracle的备份和恢复工具RMAN(Recovery Manager)进行备份。RMAN提供了全面而高效的数据库备份和恢复功能。您可以使用RMAN备份数据库的SQL文件,并将其存储在指定的位置。可以使用RMAN备份的命令来备份数据库,例如:

    2024年01月25日
    浏览(50)
  • DB(一):数据库概述、SQL概述、Oracle数据类型

    包括Oracle、DB2、SQL Server、MySQL数据库概述;数据定义语言DDL、数据操作语言DML、事务控制语言TCL、数据查询语言DQL、数据控制语言DCL语言介绍;NUMBER 、CHAR、VARCHAR2、DATE数据库类型;CHAR和VARCHAR2的存储编码、CHAR和VARCHAR2的最大长度、LONG和CLOB类型。 1、DB和DBMS (1)、数据库(

    2024年02月09日
    浏览(53)
  • ORACLE数据库 —— PL/SQL知识点2

    ORACLE数据库  PL/SQL语句基础知识点  适合有SQL基础的人群。  禁止转载! 内置函数 字符串函数     lower(列名|字符串)函数用于返回字符串的小写形式。         eg.SELECT ename,sal FROM emp WHERE ename=lower(\\\'ename\\\');     upper(列名|字符串)函数用于返回字符串的大写形式。       

    2024年02月08日
    浏览(12)
  • Oracle/PL/SQL数据库基础操作(持续更新)

    Oracle/PL/SQL数据库基础操作(持续更新)

            PL/SQL不是一个独立的编程语言;它是Oracle编程环境中的工具。 SQL* Plus是一个互动的工具,它可以在命令提示符下键入SQL和PL/SQL语句。这些命令发送到数据库进行处理。语句处理之后将结果发回,并在屏幕上显示出来。 分类 命令 DDL create:创建;drop:删除;alter:

    2024年02月09日
    浏览(10)
  • SQL SERVER连接oracle数据库几种方法

    --1 方式  --查询oracle数据库中的表  举一反三:在查询分析器中输入: --在sqlserver中创建与oracle数据库中的表同名的表  --2、方式  --在master数据库中查看已经存在的链接服务器  --要在企业管理器内指定登录帐号 --备注:引用ORACLE服务器上的表时,用户名称与表名一定要大写

    2024年02月02日
    浏览(14)
  • SQL Developer的下载、安装和连接Oracle数据库

    SQL Developer的下载、安装和连接Oracle数据库

    SQL Developer–Oracle常用管理工具。 如需SQL Developer安装包可以下方留言。 该软件不需要安装,下载解压后 双击sqldeveloper.exe即可运行 。 第一次运行需要输入JDK路径。 【若没下载或不清楚是否已经下载JDK,指路下载、安装JDK并检测JDK是否安装成功】 SQL Developer是图形界面查询工

    2024年02月07日
    浏览(10)
  • 用PL/SQL Developer连接远程Oracle数据库

    用PL/SQL Developer连接远程Oracle数据库

    oracle数据库安装教程参考 注意: 第六步中的Oracle基目录中的用户名为中文的话,需要去掉中文部分。然后管理口令一定保存好。 2.打开oracle安装目录(默认在C盘,我的在D盘),找到tnsnames.ora文件 这是oracle客户端所需要的一个文件,通过该文件可以配置数据库的连接地址,

    2024年02月13日
    浏览(10)
  • 主流数据库(SQL Server、Mysql、Oracle)通过sql实现多行数据合为一行

    主流数据库(SQL Server、Mysql、Oracle)通过sql实现多行数据合为一行

    1、方法一:使用 STUFF 和 FOR XML PATH 进行多行合并成一行 (1)FOR XML PATH用法 FOR XML 是 SQL Server 提供的一种功能,允许您将查询结果转换为 XML 格式。 PATH 模式则是其中一种灵活的方式来构造自定义的XML结构。 1、基本字符串连接 : 当您想从单列中提取所有行的数据并连接成一

    2024年04月10日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包