实验六 模式对象管理与安全管理

简介: 实验六 模式对象管理与安全管理

😘欢迎关注:👍点赞🙌收藏✍️留言

🏇码字不易,你的👍点赞🙌收藏❤️关注对我真的很重要,有问题可在评论区提出,感谢阅读!!!

实验六 模式对象管理与安全管理

【实验目的】

  1. 了解模式对象的类型
  2. 掌握命令方式建立表、视图、索引等常见对象的方法
  3. 了解保存点、回退、提交操作
  4. 熟悉Oracle中权限分类和设置,理解系统提供用户的角色和权限
  5. 熟练使用建立用户、角色,为用户授权、授予角色的命令

【实验内容】

  1. 创建一个TESTUSER用户,密码为test,默认表空间为users表空间,在users表空间中quota属性为unlimited
  • 编写程序
create user TESTUSER
IDENTIFIED BY test
default tablespace users
quota unlimited on users;
  • 运行结果

  1. 创建用户后为其授予登录数据库和创建数据库对象的权限
  • 编写程序
grant connect,resource to TESTUSER;
  • 运行结果

  1. TESTUSER用户登录数据库
  • 编写程序
conn testuser/test
  • 运行结果

  1. 创建学生信息表(学号,姓名,性别,入学成绩),定义主键和输入数据(至少5条数据),提交添加的数据。并完成下面的题目:

4.1.创建学生信息表并插入数据

  • 编写程序
create table stu_table
  (
    stu_no char(8) primary key not null,
    stu_name varchar2(10) not null,
    stu_sex char(1) not null,
    stu_grade float not null
  );
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20180001', 'Lunatic', 'M', 488.2);
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20180002', 'Insane', 'M', 391.5);
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20180003', 'Mad', 'M', 477.8);
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20180004', 'Faze Clan', 'F', 489.2);
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20180005', 'Astralis', 'F', 590.2);
  1. 再继续添加2条数据,设置一个保存点savepoint,再添加1条数据,执行回退到保存点的回退命令。查看此时表中数据
  • 添加2条数据
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20210006', 'ARSENAL', 'M', 591.2);
  insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
  values ('20210007', 'Chelsea', 'M', 488.5);
  • 设置一个保存点
savepoint key_rollback;
 

  • 再添加一条数据
insert into stu_table(stu_no, stu_name, stu_sex, stu_grade)
values ('20210008', 'Man Utd', 'M', '388.7');

  • 回退到保存点的位置
rollback to key_rollback;

  • 查看表中数据,可以看到学号为20210008的学生信息消失。
select * from stu_table;

  1. 查询入学成绩大于480的学生信息
select * from stu_table
where stu_grade > 480;

  1. 建立男生信息视图(创建视图的权限需要提前授予)
  • 授予创建视图的权限(注意切换到有权限的用户下进行授权)
grant create view to testuser;

  • 建立男生信息视图
  create view view_male
  as
  select * from stu_table
  where stu_sex = 'M';

  1. 在“成绩”字段上建立B-树索引
create index B_index on testuser.stu_table(stu_grade);

  1. 在testuser用户登录下,创建一个表簇,名为empl_dep,容纳empl表和dep表,有公共字段depno(簇键),大小为500,默认表空间为USERS表空间,存储参数为:初始化区间大小为100K,第二区间为200K等。
  • 编写程序
create cluster empl_dep(depno varchar2(4))
size 500
tablespace users storage(
  initial 100 K
  next 200 K
  minextents 2
  maxextents 20
  pctincrease 33
);

运行结果

  ![](https://ucc.alicdn.com/images/user-upload-01/img_convert/2da75772f4e8bb3e1fe4c4a60fec478d.png)
  1. 在表簇中建立empl表和dep表
  1. empl表(职员表)的主键为eno,外键为depno (需要先建立dep表)
  • 编写程序
  create table empl
  (
    e_no varchar(10) primary key,
    e_name varchar(10) not null,
    e_sex varchar(2),
    depno varchar(4) not null references dep
  )
  cluster empl_dep(depno);


  • 运行结果

  1. dep表(部门表)的主键为depno。
  • 编写程序
  create table dep
  (
    depno varchar(4) primary key,
    d_name varchar(10) not null,
    rs number
  )
  cluster empl_dep(depno);
  • 运行结果
![](https://ucc.alicdn.com/images/user-upload-01/img_convert/6260e2a01124809151829d3bce727cee.png)
  1. 在表簇中建立一个簇键索引,名为empl_dep_index。
  • 编写程序
create index empl_dep_index
on cluster empl_dep tablespace users;


  1. 授予scott用户在empl表上的所有权限,提示:授权和收回权限可在sys/system/testuser用户登录以后进行授权。
  1. 授权
  • 编写程序
grant all on empl to scott;
  • 运行结果

  1. 授权后,更改为scott用户登录,测试是否能对empl表进行查改增删
  • 在这之前先给dep表插入数据

  • 然后到SCOTT用户下对empl表进行操作
  • 登录SCOTT

  • 插入数据

  • 查看数据

  • 删除数据

  • 修改数据

  1. 收回scott用户拥有的empl表上DELETE权限,再次测试scott用户对empl表的删除操作是否还能执行
  • 在testuser用户下收回scott用户拥有的empl表上DELETE权限

  • 登录SCOTT用户测试是否可以对empl表进行删除

【实验总结】

本次实验着重介绍了模式对象管理和安全管理的知识。通过实验,我们学习了创建用户、授权和权限设置的方法,以及使用命令创建表、视图、索引等数据库对象的技巧。我们还学会了保存点、回退和提交操作的运用,以及如何建立和管理用户角色和权限。此外,我们还学习了在表簇中建立索引和授予权限的操作。通过这次实验,我们对数据库的结构管理和安全性有了更深入的理解,为今后的数据库管理工作打下了坚实基础。


相关文章
|
22天前
|
Kubernetes 持续交付 开发工具
三类代码协同模式,你要如何选?
三类代码协同模式,Git大神告诉你到底如何选。
|
22天前
|
监控 项目管理
问题管理的方法
问题管理的方法
问题管理的方法
|
6月前
|
安全 数据库 数据安全/隐私保护
特权账号管理的重点
账号权限的最小化是目前对特权账号权限管理的主要原则之一,但在实际的工作中,通常情况下,账号权限的会因为要保障业务顺利开展而进行扩大
64 0
|
9月前
|
存储 安全 网络安全
it网络构建及设备系统配置以及IT安全策略实施如何实现?
it网络构建及设备系统配置以及IT安全策略实施如何实现?
|
数据采集 架构师 数据管理
「数据架构」:建立企业数据管理的综合策略 执行概述
「数据架构」:建立企业数据管理的综合策略 执行概述
|
安全 算法
【系统分析】IT 审计之内部控制环节
【系统分析】IT 审计之内部控制环节
162 0
|
运维 监控 API
谈身份管理之进阶篇 - 快速了解从管理到治理的最佳方案
云上身份安全是当今企业管理者和云上运维团队所面临的挑战之一,针对云上身份管理不全面所产生的风险究竟又哪些?又应当如何应对?本文将结合案例和最佳实践与您分享。
谈身份管理之进阶篇 - 快速了解从管理到治理的最佳方案
|
存储 SQL 人工智能
零信任策略下云上安全信息与事件管理最佳实践
随着企业数字化转型的深入推进,网络安全越来越被企业所重视。为了构建完备的安全防御体系,企业通常会引入了防火墙(Firewall)、防病毒系统(Anti-Virus System,AVS)、入侵防御系统(Intrusion Prevention System,IPS)、入侵检测系统(Intrusion Detection System,IDS)、审计系统等大量安全产品,然而这些安全产品往往各自为政、缺乏联动,难以形成有价值的、全面系统的安全态势分析报告,也就难以应对复杂多变的安全威胁。
零信任策略下云上安全信息与事件管理最佳实践
|
运维 安全 数据安全/隐私保护
使用管控策略,设定多账号组织全局访问边界
企业上云多账号架构中,如何做到从上到下管理的同时,处理好员工的权限边界问题?
4957 0

热门文章

最新文章