【赵渝强老师】崖山数据库的数据字典

YashanDB通过读取数据字典从而比较方便地获取有关用户、对象和存储结构等信息。当系统执行了DDL语句后,YashanDB数据库会及时修改数据字典中的信息。普通用户只能以读的形式使用数据字典获取数据库信息,数据字典由YashanDB系统自动来进行维护。

视频讲解如下
【赵渝强老师】崖山数据库的数据字典

一、 数据字典的简介

数据字典是YashanDB存放有关数据库信息的地方,几乎所有的数据库信息和对象信息都可在数据字典中进行查询,它是随着数据库的建立而建立的。数据字典是YashanDB数据库系统的信息核心,它是一组提供有关数据库信息的表和视图的集合。对于普通用户而言,这些表和视图是只读的。YashanDB数据库的管理员sys用户是数据字典的拥有者,数据字典的数据保存在系统表空间system中。

YashanDB的数据字典有4种不同的命名前缀。下面列举了这4种前缀以及他们的含义。

  • user_

该数据字典只提供当前用户下的数据库对象信息。例如,下面的语句将查询当前用户所创建的数据库对象的名称和类型。

sql 复制代码
SQL> select object_name, object_type from user_objects;
  • all_

该数据字典提供中的数据表示当前用户有关的对象信息。例如下面的语句将查询当前用户可访问到的数据库对象的名称和对象的类型。

sql 复制代码
SQL> select object_name, object_type from all_objects;
  • dba_

该数据字典中的数据只有数据库管理员才可读取的视图。

  • v$

该数据字典是YashanDB的动态性能视图,用于记录当前YashanDB数据库实例在运行过程中的状态信息。因此,动态性能视图对于诊断YashanDB数据库的性能非常重要。

二、 【实战】查询YashanDB数据字典中的信息

在了解到了YashanDB数据字典的基本信息后,下面通过几个具体的示例来演示如何从数据字典获取相关的信息。

(1)使用scott用户查看当前用户的默认表空间

sql 复制代码
SQL> conn scott/tiger
SQL> select username, default_tablespace from user_users;

# 输出的信息如下:
USERNAME           DEFAULT_TABLESPACE   
------------------ -------------------- 
SCOTT              USERS               

1 row fetched.

(2)使用scott用户查看当前用户角色

sql 复制代码
SQL> select * from user_role_privs;

# 输出的信息如下:
GRANTEE         GRANTED_ROLE     ADMIN_OPTION 
--------------- ---------------- ------------ 
SCOTT           CONNECT          N           
SCOTT           RESOURCE         N           

2 rows fetched.

(3)使用sys用户查看表空间的信息。

sql 复制代码
SQL> conn sys/Welcome_1
SQL> select tablespace_name, sum(bytes), sum(blocks) 
     from dba_free_space group by tablespace_name; 

# 输出的信息如下:
TABLESPACE_NAME     SUM(BYTES) SUM(BLOCKS) 
------------------ ----------- ----------- 
SYSTEM                20054016        2448
SYSAUX                63242240        7720
TEMP                  61865984        7552
SWAP                  66060288        8064
USERS                 75169792        9176
UNDO                 100155392       12226

6 rows fetched.

(4)使用sys用户查看用scott创建表的信息。

sql 复制代码
SQL> select owner,object_name,object_type
     from dba_objects 
     where object_type='TABLE' and OWNER='SCOTT';  

# 输出的信息如下:
OWNER               OBJECT_NAME     OBJECT_TYPE           
------------------- --------------- --------------------- 
SCOTT               DEPT            TABLE                
SCOTT               EMP             TABLE                

2 rows fetched.
相关推荐
kaico20181 小时前
FastAPI 框架 - 高级部分
oracle·fastapi
java_cj1 小时前
MySQL 8.0 新特性深度解析:降序索引、Doublewrite Buffer 与 redo log 无锁优化
数据库·mysql
网管NO.12 小时前
多表联查入门|INNER JOIN 内连接,关联查询基础(实操案例)
数据库·sql
devilnumber2 小时前
MySQL 索引失效 20 例
数据库·mysql
念恒123062 小时前
MySQL事务(上)
数据库·mysql
devilnumber2 小时前
MySQL 执行计划(EXPLAIN)背诵版
数据库·mysql
念恒123062 小时前
MySQL视图
数据库·mysql
!沧海@一粟!2 小时前
Linux高并发内核优化
linux·运维·oracle
我叫张小白。2 小时前
基于Redis的缓存架构与一致性保障体系
数据库·redis·缓存·架构