MySQL和Oracle对比学习之数据字典元数据

本文涉及的产品
RDS Agent(兼容Hermes Agent),2核4GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: MySQL和Oracle虽然在架构上有很大的不同,但是如果从某些方面比较起来,它们有些方面也是相通的。 毕竟学习的主线是MySQL,所以会从MySQL的角度来对比Oracle的一些功能。
MySQL和Oracle虽然在架构上有很大的不同,但是如果从某些方面比较起来,它们有些方面也是相通的。
毕竟学习的主线是MySQL,所以会从MySQL的角度来对比Oracle的一些功能。 大体总结了以下的内容,欢迎大家拍砖,
查看当前的数据库名
mysql> SELECT DATABASE();
+------------+
| DATABASE() |
+------------+
| test         |
+------------+
1 row in set (0.00 sec)

+++ Oracle的实现方法 ++++
因为架构的不同,所以列举了数据库,实例级的查询方法。
方法一,通过数据库参数来查看
SQL> show parameter instance_name
NAME                                 TYPE                              VALUE
------------------------------------ --------------------------------- ------------------------------
instance_name                        string                            TRUABP4

方法二:通过数据字典来查看
数据库级
SQL> select name from v$database;
NAME
---------------------------
TRUABP4

实例级
SQL> select instance_name from v$instance;
INSTANCE_NAME
------------------------------------------------
TRUABP4
方法三:通过内置函数来实现,这种方法相比前两种更为通用。
SQL> select sys_context('USERENV','instance_name') from dual;
SYS_CONTEXT('USERENV','INSTANCE_NAME')
----------------------------------------------------
TRUABP4

得到数据库创建的脚本
得到数据库名为mysql的创建脚本,毕竟在架构实现上不同,有点类似oracle中的用户级别。

mysql> show create database mysql;
+----------+------------------------------------------------------------------+
| Database | Create Database                                                  |
+----------+------------------------------------------------------------------+
| mysql    | CREATE DATABASE `mysql` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+----------+------------------------------------------------------------------+
1 row in set (0.00 sec)

+++  Oracle的实现方法 ++++
Oracle中的实现方式相比要复杂很多。叫法一样,但是实现还是有很大的差别。

CREATE DATABASE mynewdb
   USER SYS IDENTIFIED BY pz6r58
   USER SYSTEM IDENTIFIED BY y1tz5p
   LOGFILE GROUP 1 ('/u01/oracle/oradata/mynewdb/redo01.log') SIZE 100M,
           GROUP 2 ('/u01/oracle/oradata/mynewdb/redo02.log') SIZE 100M,
           GROUP 3 ('/u01/oracle/oradata/mynewdb/redo03.log') SIZE 100M
   MAXLOGFILES 5
   MAXLOGMEMBERS 5
   MAXLOGHISTORY 1
   MAXDATAFILES 100
   MAXINSTANCES 1
   CHARACTER SET US7ASCII
   NATIONAL CHARACTER SET AL16UTF16
   DATAFILE '/u01/oracle/oradata/mynewdb/system01.dbf' SIZE 325M REUSE
   EXTENT MANAGEMENT LOCAL
   SYSAUX DATAFILE '/u01/oracle/oradata/mynewdb/sysaux01.dbf' SIZE 325M REUSE
   DEFAULT TEMPORARY TABLESPACE tempts1
      TEMPFILE '/u01/oracle/oradata/mynewdb/temp01.dbf' 
      SIZE 20M REUSE
   UNDO TABLESPACE undotbs 
      DATAFILE '/u01/oracle/oradata/mynewdb/undotbs01.dbf'
      SIZE 200M REUSE AUTOEXTEND ON MAXSIZE UNLIMITED;

查看当前的用户
mysql> SELECT USER();
+----------------+
| USER()         |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)

+++  Oracle的实现方法 ++++
方法一,通过sql*plus中的show user命令杰克得到
SQL> show user
USER is "N1"
方法二:通过内置函数来实现,比较通用的方式。
SQL> select sys_context('USERENV','current_user') from dual;
SYS_CONTEXT('USERENV','CURRENT_USER')
--------------------------------------------------
N1

查看含有的表信息
mysql> show tables;     
+---------------------------+
| Tables_in_mysql           |
+---------------------------+                                                  
| columns_priv              |
| db                        |                                                  
| event                     |                                                  
| func                      |
| general_log               |                                                  
| help_category             |                                               
| time_zone_transition_type |                                                  
| user                      |                                                  
+---------------------------+
28 rows in set (0.00 sec)  

+++  Oracle的实现方法 ++++
方法一:通过cat同义词来实现

SQL> select *from cat where rownum TABLE_NAME                TABTYPE             
------------------ --------------------- 
AAA                  TABLE
AAAA                 TABLE
方法二:通过tab同义词来实现
SQL> select *from tab where rownum TNAME                TABTYPE                CLUSTERID
------------------ --------------------- ----------
AAA                  TABLE
AAAA                 TABLE
方法三:通过数据字典user_tables来实现
SQL> select table_name from user_tables where rownum TABLE_NAME
------------------
AAA
AAAA

查看指定数据库中的表信息
比如查询数据库名为mysql里面含有的表。
mysql> show tables from mysql;           
+---------------------------+                                                  
| Tables_in_mysql           |            
+---------------------------+                                                  
| columns_priv              |                                                  
| db                        |            
| event                     |                                                  
| func                      |            
| general_log               |            
| help_category             |            
| help_keyword              |            
| help_relation             |            
| time_zone_transition_type |            
| user                      | 
+---------------------------+
28 rows in set (0.00 sec)       

+++  Oracle的实现方法 ++++
Oracle中的实现还是根据数据字典表*_tables

SQL> select table_name from all_tables where owner='REFWORK';
TABLE_NAME
------------------------------
OFFER

查看test数据库中的表temp结构
> mysql show test temp
Database: test  Table: temp
+---------+-------------+-----------------+------+-----+---------+--------------
| Field   | Type        | Collation       | Null | Key | Default | Extra
+---------+-------------+-----------------+------+-----+---------+--------------
| id      | int(11)     |                 | NO   | PRI |         | auto_incremen
| char    | char(50)    | utf8_general_ci | NO   | MUL |         |              
| varchar | varchar(50) | utf8_general_ci | NO   | MUL |         |              
| text    | text        | utf8_general_ci | NO   | MUL |         |
+---------+-------------+-----------------+------+-----+---------+--------------

+++  Oracle的实现方法 ++++
可以通过all_tab_cols来实现
select table_name,column_name from all_tab_cols where owner='N1' and table_name='TEST';

查看表的建表语句
mysql> show create table event\G                                                
*************************** 1. row ***************************
       Table: event                                                             
Create Table: CREATE TABLE `event` (
  `db` char(64) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '',        
  `name` char(64) NOT NULL DEFAULT '',                                          
  `body` longblob NOT NULL,                                                     
  `definer` char(77) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL DEFAULT '',   
  `execute_at` datetime DEFAULT NULL,                                           
  `body_utf8` longblob,                                               
  PRIMARY KEY (`db`,`name`)                                                     
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Events'                           
1 row in set (0.00 sec) 


+++  Oracle的实现方法 ++++
oracle中一直直观的方式是使用dbms_metadata.get_ddl来实现  
SQL> select  DBMS_METADATA.GET_DDL(object_type=>'TABLE',name=>'CSM_OFFER')from dual
DBMS_METADATA.GET_DDL(OBJECT_TYPE=>'TABLE',NAME=>'CSM_OFFER')
--------------------------------------------------------------------------------
  CREATE TABLE "REFWORK"."OFFER"
   (    "OWNER" VARCHAR2(30) NOT NULL ENABLE,
        "OBJECT_NAME" VARCHAR2(30) NOT NULL ENABLE,
        "SUBOBJECT_NAME" VARCHAR2(30),
        "OBJECT_ID" NUMBER NOT NULL ENABLE,
        "DATA_OBJECT_ID" NUMBER,
        "OBJECT_TYPE" VARCHAR2(19),
        "CREATED" DATE NOT NULL ENABLE,
        "LAST_DDL_TIME" DATE NOT NULL ENABLE,
        "TIMESTAMP" VARCHAR2(19)...

得到表结构的信息
mysql> desc columns_priv
    -> ;
+-------------+----------------------------------------------+------+-----+-----
| Field       | Type                                         | Null | Key | Defa
+-------------+----------------------------------------------+------+-----+-----
| Host        | char(60)                                     | NO   | PRI |
| Db          | char(64)                                     | NO   | PRI |
| User        | char(16)                                     | NO   | PRI |
| Table_name  | char(64)                                     | NO   | PRI |
| Column_name | char(64)                                     | NO   | PRI |
| Timestamp   | timestamp                                    | NO   |     | CURR
| Column_priv | set('Select','Insert','Update','References') | NO   |     |
+-------------+----------------------------------------------+------+-----+-----
7 rows in set (0.01 sec)

+++  Oracle的实现方法 ++++
这一点完全一样
SQL> desc offer
 Name                                      Null?    Type
 ----------------------------------------- -------- ----------------------------
 OWNER                                     NOT NULL VARCHAR2(30)
 OBJECT_NAME                               NOT NULL VARCHAR2(30)
 SUBOBJECT_NAME                                     VARCHAR2(30)
 OBJECT_ID                                 NOT NULL NUMBER
 DATA_OBJECT_ID                                     NUMBER
 OBJECT_TYPE                                        VARCHAR2(19)
 CREATED                                   NOT NULL DATE
 LAST_DDL_TIME                             NOT NULL DATE
 TIMESTAMP                                          VARCHAR2(19)
 STATUS                                             VARCHAR2(7)
 TEMPORARY                                          VARCHAR2(1)
 GENERATED                                          VARCHAR2(1)
 SECONDARY                                          VARCHAR2(1)

得到表中的列信息
mysql> show columns from columns_priv;
+-------------+----------------------------------------------+------+-----+-----
| Field       | Type                                         | Null | Key | Defa
+-------------+----------------------------------------------+------+-----+-----
| Host        | char(60)                                     | NO   | PRI |
| Db          | char(64)                                     | NO   | PRI |
| User        | char(16)                                     | NO   | PRI |
| Table_name  | char(64)                                     | NO   | PRI |
| Column_name | char(64)                                     | NO   | PRI |
| Timestamp   | timestamp                                    | NO   |     | CURR
| Column_priv | set('Select','Insert','Update','References') | NO   |     |
+-------------+----------------------------------------------+------+-----+-----
7 rows in set (0.01 sec)

+++  Oracle的实现方法 ++++
通过user_tab_cols来实现。  
SQL> select column_name from user_tab_cols where table_name='OFFER';
COLUMN_NAME
------------------------------
OWNER
OBJECT_NAME
SUBOBJECT_NAME
OBJECT_ID
DATA_OBJECT_ID
OBJECT_TYPE
CREATED
LAST_DDL_TIME

得到索引的信息
mysql> show index from columns_priv;
+--------------+------------+----------+--------------+-------------+-----------
| Table        | Non_unique | Key_name | Seq_in_index | Column_name | Collation
+--------------+------------+----------+--------------+-------------+-----------
| columns_priv |          0 | PRIMARY  |            1 | Host        | A
| columns_priv |          0 | PRIMARY  |            2 | Db          | A
| columns_priv |          0 | PRIMARY  |            3 | User        | A
| columns_priv |          0 | PRIMARY  |            4 | Table_name  | A
| columns_priv |          0 | PRIMARY  |            5 | Column_name | A
+--------------+------------+----------+--------------+-------------+-----------
5 rows in set (0.00 sec)

+++  Oracle的实现方法 ++++
通过User_indexes来实现
SQL> select index_name,index_type from user_indexes where table_name='OFFER';
INDEX_NAME                     INDEX_TYPE
------------------------------ ---------------------------
INX_OFFER                      NORMAL

基于列的模糊查找
可能在这方面MySQL提供的直观方式要多一些。

mysql> show columns from columns_priv like '%ab%';
+------------+----------+------+-----+---------+-------+
| Field      | Type     | Null | Key | Default | Extra |
+------------+----------+------+-----+---------+-------+
| Table_name | char(64) | NO   | PRI |         |       |
+------------+----------+------+-----+---------+-------+
1 row in set (0.01 sec)

+++  Oracle的实现方法 ++++
Oracle里面还是用user_tab_cols,一用倒底。

SQL> select column_name from user_tab_cols where table_name='OFFER' and column_name like '%OBJE%';
COLUMN_NAME
------------------------------
OBJECT_NAME
SUBOBJECT_NAME
OBJECT_ID
DATA_OBJECT_ID
OBJECT_TYPE

精确查找列名
mysql> show columns from columns_priv where field='User';
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| User  | char(16) | NO   | PRI |         |       |
+-------+----------+------+-----+---------+-------+
1 row in set (0.01 sec)

+++  Oracle的实现方法 ++++
还是使用usre_tab_cols,一用倒底。
SQL> select column_name from user_tab_cols where table_name='OFFER' and column_name= 'OBJECT_NAME';
COLUMN_NAME
------------------------------
OBJECT_NAME

查看进程相关的信息
mysql> show processlist
    -> ;
+----+------+-----------------+-------+---------+------+-------+----------------
| Id | User | Host            | db    | Command | Time | State | Info
+----+------+-----------------+-------+---------+------+-------+----------------
|  3 | root | localhost:49479 | mysql | Query   |    0 | init  | show processlis
+----+------+-----------------+-------+---------+------+-------+----------------
1 row in set (0.00 sec)

+++  Oracle的实现方法 ++++
Oracle中提供了比较全面的视图,可以通过v$session,v$process来查找
USERNAME                       MACHINE              PROGRAM                   SID
------------------------------ -------------------- ------------------------- ----------
    REFWORK                     rac1                 sqlplus@rac1 (TNS V1-V3)  257


select *from v$process;

查看数据字典的信息
MySQL中的数据字典信息都包含在schema information_schema里面

>mysqlshow information_schema
Database: information_schema
+---------------------------------------+
|                Tables                 |
+---------------------------------------+
| CHARACTER_SETS                        |
| COLLATIONS                            |
| COLLATION_CHARACTER_SET_APPLICABILITY |
| COLUMNS                               |
| COLUMN_PRIVILEGES                     |
| ENGINES                               |
| EVENTS                                |
| FILES                                 |
| GLOBAL_STATUS                         |
| GLOBAL_VARIABLES                      |
| KEY_COLUMN_USAGE                      |
| OPTIMIZER_TRACE                       |
| PARAMETERS                            |
| PARTITIONS                            |
| PLUGINS                               |
| PROCESSLIST                           |
| PROFILING                             |
| REFERENTIAL_CONSTRAINTS               |
| ROUTINES                              |
+---------------------------------------+

+++  Oracle的实现方法 ++++
Oracle中的视图更加丰富,除了常说的数据字典表,还有动态性能视图,调优诊断很是方便。
select *from dict;  --数据字典表
select *from v$fixed_table;--动态性能视图表



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
8月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
895 6
|
9月前
|
SQL 关系型数据库 MySQL
Mysql基础学习day01
本课程为MySQL基础学习第一天内容,涵盖MySQL概述、安装、SQL简介及其分类(DDL、DML、DQL、DCL)、数据库操作(查询、创建、使用、删除)及表操作(创建、约束、数据类型)。适合初学者入门学习数据库基本概念和操作方法。
298 6
|
9月前
|
关系型数据库 MySQL 数据管理
Mysql基础学习day03-作业
本内容包含数据库建表语句及多表查询示例,涵盖内连接、外连接、子查询及聚合统计,适用于员工与部门数据管理场景。
172 1
|
9月前
|
SQL 关系型数据库 MySQL
Mysql基础学习day02-作业
本教程介绍了数据库表的创建与管理操作,包括创建员工表、插入测试数据、删除记录、更新数据以及多种查询操作,涵盖了SQL语句的基本使用方法,适合初学者学习数据库操作基础。
191 0
|
9月前
|
SQL 关系型数据库 MySQL
Mysql基础学习day03
本课程为MySQL基础学习第三天内容,主要讲解多表关系与多表查询。内容涵盖物理外键与逻辑外键的区别、一对多、一对一及多对多关系的实现方式,以及内连接、外连接、子查询等多表查询方法,并通过具体案例演示SQL语句的编写与应用。
262 0
|
9月前
|
SQL 关系型数据库 MySQL
Mysql基础学习day01-作业
本教程包含三个数据库表的创建练习:学生表(student)要求具备主键、自增长、非空、默认值及唯一约束;课程表(course)定义主键、非空唯一字段及数值精度限制;员工表(employee)包含自增主键、非空字段、默认值、唯一电话号及日期时间类型字段。每个表的结构设计均附有详细SQL代码示例。
173 0
|
9月前
|
SQL 关系型数据库 MySQL
Mysql基础学习day02
本课程为MySQL基础学习第二天内容,涵盖数据定义语言(DDL)的表查询、修改与删除操作,以及数据操作语言(DML)的增删改查功能。通过具体SQL语句与实例演示,帮助学习者掌握MySQL表结构操作及数据管理技巧。
236 0
|
Oracle 关系型数据库 Java
【YashanDB知识库】Flink CDC实时同步Oracle数据到崖山
本文介绍通过Flink CDC实现Oracle数据实时同步至崖山数据库(YashanDB)的方法,支持全量与增量同步,并涵盖新增、修改和删除的DML操作。内容包括环境准备(如JDK、Flink版本等)、Oracle日志归档启用、用户权限配置、增量日志记录设置、元数据迁移、Flink安装与配置、生成Flink SQL文件、Streampark部署,以及创建和启动实时同步任务的具体步骤。适合需要跨数据库实时同步方案的技术人员参考。
【YashanDB知识库】Flink CDC实时同步Oracle数据到崖山
|
Oracle 关系型数据库 MySQL
Oracle linux 8 二进制安装 MySQL 8.4企业版
Oracle linux 8 二进制安装 MySQL 8.4企业版
614 1
|
分布式计算 关系型数据库 MySQL
E-Mapreduce如何处理RDS的数据
目前网站的一些业务数据存在了数据库中,这些数据往往需要做进一步的分析,如:需要跟一些日志数据关联分析,或者需要进行一些如机器学习的分析。在阿里云上,目前E-Mapreduce可以满足这类进一步分析的需求。
5252 0

推荐镜像

更多