openGauss开源数据库实战十四

文章目录

  • 任务十四 openGauss 逻辑结构:视图管理
    • 任务目标
    • 实施步骤
      • 一、准备工作
      • 二、为什么需要视图
        • 1.通过视图对用户隐藏信息
        • 2.创建一个比逻辑模型更符合用户直觉的表
      • 三、创建视图时指定视图的属性名
      • 四、基于视图建立新的视图
      • 五、物化视图
      • 六、视图失效(openGauss暂不支持)
      • 七、通过视图更新基表(openGauss暂不支持)
      • 八、清理工作

任务十四 openGauss 逻辑结构:视图管理

任务目标

在三级模式二级映射体系中,可以将概念模式映射为外模式。视图是将概念模式映射为外模式的手段。本任务的目的是掌握openGauss视图的管理:创建视图、删除视图、查询视图的信息、修改视图的信息。

实施步骤

一、准备工作

执行下列的命令和语句,创建一个名叫pupil的数据库用户,并授予用户pupil访问数据库pupildb的权限:

gsql -d postgres -p 26000 -r
CREATE USER pupil IDENTIFIED BY 'pupil@ustb2020';
GRANT CONNECT on DATABASE studentdb TO pupil;
\q

二、为什么需要视图

1.通过视图对用户隐藏信息

使用Linux用户omm,打开一个Linux终端窗口,执行如下命令,使用用户student连接到openGauss的数据库studentdb,并查询表instructor的内容:

gsql -d studentdb -h 192.168.100.91 -U student -p 26000 -W student@ustb2020 -r
select * from instructor;

我们发现,只要有访问表instructor的权限,用户就能看到该表的所有信息。要想限制用户权限使其不能看到教师的salary信息,方法是创建一个视图,并授予用户pupil读取视图faculty的权限:

create or replace view faculty asselect ID, name, dept_namefrom instructor;
GRANT SELECT ON faculty TO pupil;
\q

在这里插入图片描述

打开另外一个Linux终端窗口,使用数据库用户pupil连接到数据库studentdb:

gsql -d studentdb -h 192.168.100.91 -U pupil -p 26000 -W pupil@ustb2020 -r

执行下面的gsql元命令,看看数据库用户pupil能查看到哪些表名和视图名:

\dtv

执行下面的SQL语句,查看视图faculty的内容:

select * from faculty;

执行下面的SOL语句,查看表instructor的内容:

select * from instructor;
\q

在这里插入图片描述

由于数据库用户pupil没有被授权访问表instructor,因此它无法看到表instructor的内容,但是数据库用户pupil被授权可以访问视图faculty,而视图faculty屏蔽了表instructor中的敏感信息salary。

2.创建一个比逻辑模型更符合用户直觉的表

使用Linux用户omm,打开一个Linux终端窗口,执行如下命令,使用用户student连接到openGauss的数据库studentdb:

gsql -d studentdb -h 192.168.100.91 -U student -p 26000 -W student@ustb2020 -r

假如希望有一个关于物理系在2009年秋季学期所开设的所有课程段的表,可以创建以下的视图:

create or replace view physics_fall_2009 asselect course.course_id, sec_id, building, room_numberfrom course, sectionwhere course.course_id = section.course_id and course.dept_name = 'Physics' and section.semester = 'Fall' and section.year = '2009';
select * from  physics_fall_2009;

然后我们可以把视图当成一个表来使用:

select * 
from  physics_fall_2009
where building= 'Watson';

在查询中,视图名可以出现在关系名可以出现的任何地方。例如,查找生物系的所有教师的信息(除了工资以外):

select * 
from faculty
where dept_name ='Biology';

在这里插入图片描述

三、创建视图时指定视图的属性名

执行下面的SOL语句,创建一个视图departments_total_salary,显示每个系所有教师的工资总和:

create or replace view departments_total_salary(dept_name, total_salary) asselect dept_name, sum(salary)from instructorgroup by dept_name;

执行下面的gsql元命令,查看数据库有哪些视图:

\dv

执行下面的gsql元命令,查看视图departments_total_salary的信息:

\dv departments_total_salary;

执行下面的gsql元命令,查看视图departments_total_salary的详细信息:

\d departments_total_salary;

可以看出,该视图的属性名是在创建视图时由用户指定的。
可以把视图当成一个表来使用:

Select * From departments_total_salary;

四、基于视图建立新的视图

我们使用前面创建的视图physics_fall_2009来创建视图physics_fall_2009_watson,该视图是关于物理系在2009年秋季学期所开设的所有在Watson大楼上课的课程段的。

create or replace view physics_fall_2009_watson asselect course_id, room_numberfrom physics_fall_2009where building= 'Watson';

这条语句相当于:

create or replace view physics_fall_2009_watson_1 asselect course_id, room_numberfrom (select course.course_id, sec_id, building, room_numberfrom course, sectionwhere course.course_id = section.course_id and course.dept_name = 'Physics' and section.semester = 'Fall' and section.year = '2009') tblwhere building= 'Watson';
\q

五、物化视图

普通视图在查询中是实时进行计算的。如果建立视图的基表数据很多,使用视图的时候进行实时计算视图表示的结果集,将消耗很大的计算机资源,并且费时很长。
物化视图可提前计算出视图的结果集,并将该结果集保存在数据库里。
如果更新了基表,物化视图将过期。也就是说,基表更新后,物化视图不能反映最新的数据情况。因此,在基表发生变化的时候,需要对物化视图进行更新。
更新物化视图的方法有两种:实时刷新、延迟刷新(可周期性自动刷新或手动刷新)。
创建一个测试表test:

gsql -d studentdb -h 192.168.100.91 -U student -p 26000 -W student@ustb2020 -r
drop materialized view if exists mv_test;
drop table if exists test;
create table test(id serial primary key,testnum serial);
insert into test(testnum) values(generate_series(1,100000));

创建物化视图:

create materialized view mv_test as 
select * 
from test 
where testnum%2=0;

查看物化视图目前有多少行记录:

select count(*) from mv_test;

为物化视图的基表test添加100000行,然后再查看物化视图当前有多少行记录:

insert into test(testnum) values(generate_series(1,100000));
select count(*) from mv_test;

我们发现,虽然物化视图mv_test的基表test添加了更多的行,但是物化视图并没有更新。
我们可以手动更新物化视图,并查看物化视图更新后有多少行记录:

refresh materialized view mv_test;
select count(*) from mv_test;
\q

在这里插入图片描述

六、视图失效(openGauss暂不支持)

七、通过视图更新基表(openGauss暂不支持)

八、清理工作

在继续后面的任务之前,关闭所有的Linux终端窗口(或者退出所有的openGaussgsql会话),打开一个Linux终端窗口,执行下面的命令和SQL语句,进行清理:

gsql -d studentdb -h 192.168.100.91 -U student -p 26000 -W student@ustb2020 -r
revoke all on faculty from pupil;
revoke CONNECT on DATABASE studentdb FROM pupil;
drop view physics_fall_2009_watson_1;
drop view physics_fall_2009_watson;
drop view physics_fall_2009;
drop view faculty;
drop materialized view if exists mv_test;
drop table if exists test;
\q

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1900.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

DICOM标准:US超声模块属性详解——超声医学的DICOM标准解析

引言 数字成像和通信在医学领域中的应用极为广泛,其中DICOM(数字成像和通信医学)标准对于确保不同设备和系统之间的兼容性和互操作性至关重要。本文将详细介绍DICOM标准中关于超声医学(Ultrasound, US)的部分&#xff…

分布式光伏管理办法

随着分布式光伏项目的不断增加,传统的管理方式已经难以满足高效、精准的管理需求。光伏业务管理系统作为一种集信息化、智能化于一体的管理工具,正在逐步成为分布式光伏项目管理的重要支撑。 光伏业务管理系统通过数字化手段实现对光伏业务全流程的精细化…

录屏+直播神器 OBS Studio 30.2.3

这款很多游戏博主都在用的录制神器,平时你看到的抖音平台上的游戏主播,大部分都用的这款直播录屏软件。同时它可以虚拟直播(绿幕虚拟背景)具体可以百度或哔哩哔哩上有详细教程 软件优点 高性能实时视频/音频捕获和混合。创建由多个…

企业应该采用和支持网络安全的几个实践

令人惊讶的是,网络安全可以像遵循最佳实践一样简单,理想情况下应该将其融入企业文化本身。在这篇文章中了解更多。 网络安全的重要性 在当今的网络安全期望中,软件工程师应该优先考虑他们的计算机系统和内部IT网络的安全性。我认为严重依赖…

ConnectX-7 25/50/100/200/400G NIC

ConnectX-7 25/50/100/200/400G NIC ConnectX-7提供了广泛的软件定义、硬件加速的网络、存储和安全功能,使组织能够现代化和保护他们的IT基础设施。此外,ConnectX-7还支持从边缘到核心数据中心到云的敏捷和高性能解决方案,同时增强网络安全性…

(代码随想录)BEllman_ford算法 及其优化 SPFA

代码随想录 (知识提炼) Bellman_ford算法 用处 解决带负权值的单源最短路问题 核心思想 对所有边进行松弛n-1次操作(n为节点数量),从而求得目标最短路。 何为松弛 minDist[B] 表示 到达B节点 最小权值,minDist[B] 有哪些状态可…

代码随想录算法训练营第十六天|530.二叉搜索树的最小绝对差、501.二叉搜索树中的众数、236. 二叉树的最近公共祖先

530.二叉搜索树的最小绝对差 题目链接:. - 力扣(LeetCode) 文章讲解:代码随想录 视频讲解:二叉搜索树中,需要掌握如何双指针遍历!| LeetCode:530.二叉搜索树的最小绝对差_哔哩哔哩…

大数据分析案例-基于随机森林算法的智能手机价格预测模型

🤵‍♂️ 个人主页:艾派森的个人主页 ✍🏻作者简介:Python学习者 🐋 希望大家多多支持,我们一起进步!😄 如果文章对你有帮助的话, 欢迎评论 💬点赞&#x1f4…

mtr mysql-test-run.pl — Run MySQL Test Suite

The mysql-test-run.pl Perl script is the main application used to run the MySQL test suite. pl Perl脚本是用来运行MySQL测试套件的主要应用程序。 It invokes mysqltest to run individual test cases. 它调用mysqltest来运行单独的测试用例。 Invoke mysql-test-run.pl…

华为云计算知识总结——及案例分享

目录 一、华为云计算基础知识二、华为云计算相关案例实战案例一:搭建弹性云服务器(ECS)并部署Web应用案例二:构建基于OBS的图片存储和分发系统案例三:基于RDS的高可用数据库应用案例四:使用华为云DDoS防护保…

计算合约方法的签名

计算合约方法的签名 通过智能合约实现 // SPDX-License-Identifier: MIT pragma solidity ^0.8.26;contract FunctionSelector {/*"transfer(address,uint256)"0xa9059cbb"transferFrom(address,address,uint256)"0x23b872dd*/function getSelector(stri…

Ant-Dseign-Pro如何去国际化及删除oneapi.json后出现程序直接结束问题的解决方案

作者:CSDN-PleaSure乐事 欢迎大家阅读我的博客 希望大家喜欢 使用环境:WebStorm 移除国际化 什么是国际化 在AntDesignPro当中,国际化就是如果你初始默认使用中文,想要切换英文,我们可以切换到英文模式。同时&#x…

太速科技-9-基于DSP TMS320C6678+FPGA XC7V690T的6U VPX信号处理卡

基于DSP TMS320C6678FPGA XC7V690T的6U VPX信号处理卡 一、概述 本板卡基于标准6U VPX 架构,为通用高性能信号处理平台,系我公司自主研发。板卡采用一片TI DSP TMS320C6678和一片Xilinx公司Virtex 7系列的FPGA XC7V690T-2FFG1761I作为主处理器&#…

Mysql当中的各种log

一、MySQL日志文件类型 重做日志(redo log)回滚日志(undo log)二进制日志(binlog)错误日志(errorlog)慢查询日志(slow query log)一般查询日志(g…

自定义规则配置教程

大家在使用waf的时候,因为业务特殊性和waf的严格校验,有时会产生误报,阻拦合法流量。 这个时候,只能通过自定义规则进行补充,选择加白名单或者黑名单。 很多人会说配置黑白名单失效了,其实95%以上都是自己…

Java项目:图书管理系统(有源代码)

Java项目:图书管理系统(有源代码) 直接上项目实现效果,文末有源码获取方式 一、技术选型 • Spring Boot、Vue、MySQL、Redis 二、功能说明 用户功能 图书查询功能 读者规则功能 查看公告 个人信息 借阅信息 违章信息 读者留言…

鸿蒙生态崛起:开发者机遇、挑战与未来展望

背景 鸿蒙系统不断发展,有与安卓、iOS 形成三足鼎立之势,且其在智能手机、智能穿戴、车载、家居等行业领域的应用越来越广泛。作为开发者,如何抓住鸿蒙生态崛起的机遇,解决开发挑战,创造更好的应用体验?欢…

MYSQL复合查询

当我们要查询的数据要使用的限制条件不是很简单的时候,可能要在一个限制条件下再次限制,比如要查找小美所在公司的平均薪资,就要先找到小美的公司,再求平均薪资。复合查询分三种,多表连接查询、子句查询和合并查询。 …

【论文阅读笔记】VLP: A Survey on Vision-language Pre-training

目录 前言2 特征提取(Feature extraction)2.1.1 图象特征提取OD-based Region feature / RoIFreeze the pre-trained object detectorsGrid features(网格特征)CNN-GFsEnd-to-End Training(端到端训练)ViT-…

U盘插入电脑不显示?别急,这里有解决方案!

随着科技的飞速发展,U盘已成为我们日常生活和工作中不可或缺的数据存储工具。然而,你是否遇到过这样的情况:满心欢喜地将U盘插入电脑,却发现电脑竟然“视而不见”,U盘图标迟迟不出现?别急,这种情…