Oracle 的视图

Oracle 的视图

源数据:

mysql 复制代码
-- Create table
create table STU_INFO
(
  id    NUMBER not null,
  name  VARCHAR2(8),
  score NUMBER(4,1),
  class VARCHAR2(2)
)
tablespace STUDENT
  pctfree 10
  initrans 1
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );
-- Create/Recreate primary, unique and foreign key constraints 
alter table STU_INFO
  add primary key (ID)
  using index 
  tablespace STUDENT
  pctfree 10
  initrans 2
  maxtrans 255
  storage
  (
    initial 64K
    next 1M
    minextents 1
    maxextents unlimited
  );

1. 创建普通视图

mysql 复制代码
CREATE [OR REPLACE] VIEW view_name [(column1, column2, ...)]
AS
SELECT column1, column2, ...
FROM table1, table2, ...
WHERE condition;
mysql 复制代码
CREATE OR REPLACE VIEW STU_INFO_VIEW AS
SELECT STU_INFO.ID,STU_INFO.NAME,STU_INFO.SCORE
FROM  STU_INFO WHERE STU_INFO.SCORE>60;
ps: 所有的视图的是基于基表的数据,相当于引用那个表的数据,当普通视图的值发生改变时,则基表值也会改变,反之亦然。

优点: 实时性,简化查询,安全性。 缺点: 影响性能,数据一致性(底层数据发生改变视图数据也会改变)

2. 创建物化视图

mysql 复制代码
CREATE [MATERIALIZED] VIEW view_name
[REFRESH {FAST|COMPLETE|FORCE ON | COMMIT | DEMAND}] -- 刷新方式 增量刷新 完全刷新  自动选择|自动刷新 手动刷新  默认:  FORCE ON COMMIT
[START WITH date_value]
[NEXT date_value]
[WITH {PRIMARY KEY|ROWID}]
[ENABLE|DISABLE] QUERY REWRITE
AS
select_statement;
mysql 复制代码
CREATE MATERIALIZED VIEW MV_STU_INFO
REFRESH FORCE ON DEMAND
AS
SELECT STU_INFO.ID,STU_INFO.NAME,STU_INFO.SCORE
FROM  STU_INFO;
mysql 复制代码
BEGIN
  DBMS_MVIEW.REFRESH('MV_STU_INFO', 'C');
END;
-- 执行手动刷新

ps:优点:性能提升,数据一致性,分布式数据处理。 缺点: 占用存储空间,数据更新延迟

3. 创建物化增量视图

mysql 复制代码
-- 前提是必须创建物化视图日志,记录基表发生了哪些变化(增删改查),用这些记录去更新物化视图
CREATE MATERIALIZED  VIEW LOG  ON "TABLE_NAME" WITH <PRIMARY KEY | ROWID>

CREATE MATERIALIZED VIEW LOG ON STU_INFO WITH ID;
CREATE MATERIALIZED VIEW MV_STU_INFO_FAST 
REFRESH FAST
AS 
SELECT ID,NAME FROM STU_INFO;

3. oracle查询表结构

mysql 复制代码
SELECT COLUMN_NAME, DATA_TYPE, DATA_LENGTH, NULLABLE
FROM ALL_TAB_COLUMNS
WHERE TABLE_NAME = 'STU_INFO'; -- 替换为实际的表名
相关推荐
奋斗者职场日记4 分钟前
redis高性能键值数据库技术简介
数据库·redis·缓存
我爱夜来香A31 分钟前
Sql进阶:字段中包含CSV,如何通过Sql解析CSV成多行多列?
数据库·sql
helloworld63791 小时前
高斯数据库Postgresql死锁和锁表解决方法
数据库·postgresql·死锁·高斯·锁表
TracyDemo2 小时前
postgresql.conf与postgresql.auto.conf区别
数据库·postgresql
小吕学编程2 小时前
开发中SQL积累
java·数据库·sql
渗透测试老鸟-九青2 小时前
通过组合Self-XSS + CSRF得到存储型XSS
服务器·前端·javascript·数据库·ecmascript·xss·csrf
Narutolxy2 小时前
深入探讨 MySQL 配置与优化:从零到生产环境的最佳实践20241112
数据库·mysql
有那么一瞬间啊2 小时前
PGSQL记录
数据库
2401_833755813 小时前
PostgreSQL 页损坏如何修复
数据库·postgresql
Elastic 中国社区官方博客4 小时前
Elasticsearch retrievers 通常与 Elasticsearch 8.16.0 一起正式发布!
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索