oracle三级模式及二级映像

  模式(schema)是数据库的一个名词,大部分的数据库在结构上都有三级模式的特征,了解下基本的概念,有助于后续深入的学习。

  用老罗坚果pro发布会的话说就是,不罗嗦,先上图。

      (图片来源于oracle-从入门到精(放)通(弃))

  三级模式的名称,分别为外模式(也叫子模式/用户模式),概念模式(也叫模式)和内模式(也叫存储模式)。

  从图上可以看出,数据库的外模式可以有多个,模式和内模式都只有一个。

  简单的理解总结:

  概念模式:oracle数据库全局逻辑结构,类似于设计方式;

  外模式:对应用户的对象,如表,索引等;

  内模式:对应存储结构,如如逻辑存储结构(表空间、区、段、块等)、物理存储结构(数据文件、控制文件、重做日志文件、初始化参数文件、配置文件等)。

概念模式(模式)

  概念模式是对oracle数据库的整体逻辑结构的一种抽象描述,不涉及具体的硬件和软件环境。

  概念模式主要描述数据的概念记录类型及其关系,还包含数据间的一些语义约束,对它的描述可以用DBMS中的DDL定义。----引自《oracle从入门到精通》

外模式

  这个就是经常用到的了,或者经常和用户打交道的模式。一般一个用户对应一个外模式。

  可以把外模式简单的理解为一个逻辑容器,存放的内容为对象的集合,这里边的对象,就是可以和用户打交道的各种数据库对象,比如表,索引,表分区/视图等等。

如何创建外模式schema

  创建数据库用户就可以了,创建完成后,会默认生成以用户名命名的schema。数据库安装的时候,会默认创建sys和system用户,因此也会有sys和system的schema。

  比如创建一个数据库用户invokerr,创建完成后,也就随之创建了一个缺省的schema,schema名字也为invokerr,invokerr可以看作是这个逻辑分区的管理员,访问本schema内的对象,如select * from user,可以不用添加schema名,相当于select * from invokerr.user。

  要访问其他schema的对象,就需要添加所属了,比如select * from scott.emp。

  oracle对象完整名称为schema.object,而不是user.object,只不过schema名和user名是相同的。scott(schema).emp(table)。

  DBMS提供子模式数据描述语言(子模式DDL)来严格定义子模式。----引自《oracle从入门到精通》

内模式

  也称存储模式(Storage Schema),它是数据物理结构和存储方式的描述,是数据在数据库内部的表示方式(例如,记录的存储方式是顺序存储、按照B树结构存储还是按hash方法存储;索引按照什么方式组织;数据是否压缩存储,是否加密)。数据库只有一个内模式。

二级映像

  映像就是一种对应关系,oracle的二级映像实际上是三种模式之间的转换关系。

  二级映像分别为外模式/模式,模式/内模式映像,作用就是在有一方发生改变后,通过改变映像,使另一方不必发生变化。

外模式/模式

  保证数据与程序的逻辑独立性。

  由于程序是依据外模式编写,在模式发生改变时,通过改变映像,外模式可以不用变化,这样程序也就不用改动。

模式/内模式

  保证数据与程序的物理独立性。

  内模式发生变化,可以改变映像,保证模式不变,这样外模式和程序也就不用发生变化。

oracle学习笔记(1)-三级模式SCHEMA的更多相关文章

  1. Oracle学习笔记—数据字典和常用命令(转载)

    转载自: oracle常用数据字典和SQL语句总结 Oracle常用命令大全(很有用,做笔记) 一.Oracle数据字典 数据字典是Oracle存放有关数据库信息的地方,其用途是用来描述数据的.比如一 ...

  2. 6. oracle学习入门系列之六 模式

    oracle学习入门系列之六 模式 上篇咱们学习记录了ORACLE数据库中的数据库结构.内存结构和进程等.篇幅 蛤蟆感觉偏多了.这次要休整下,每次笔记不宜太多,不然与书籍有何差别. 我们要保证的是每次 ...

  3. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  4. thinkphp学习笔记6—url模式

    原文:thinkphp学习笔记6-url模式 入口文件是应用的唯一入口,因为可以多入口,每个应用可以对应一个入口文件,系统会从rul参数中解析当前请求的模块,控制器,操作.ThinkPHP是区分大小写 ...

  5. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  6. Oracle学习笔记——点滴汇总

    Oracle学习笔记——点滴汇总 http://www.botangdb.com/ Oracle GI = Grid Infrastructure = ASM + Cluster

  7. Oracle学习笔记之四sp1,Oracle 11g的常用函数

    从Oracle学习笔记之四,SQL语言入门中摘出来的,独立成一章节 3.1 字符类函数 ASCII(c)和CHR(i)    分别用于返回一个字符的ASCII码和返回给定ASCII值所对应的字符. C ...

  8. Oracle学习笔记之四,SQL语言入门

    1. SQL语言概述 1.1 SQL语言特点 集合性,SQL可以的高层的数据结构上进行工作,工作时不是单条地处理记录,而对数据进行成组的处理. 统一性,操作任务主要包括:查询数据:插入.修改和删除数据 ...

  9. XML学习笔记(三) -- Schema

    标签(空格分隔): 学习笔记 Schema的格式 XML Schema文档是由元素.属性.命名空间和XML文档中的其他节点构成的. XML Schema有两种重要的Schema模型:Microsoft ...

随机推荐

  1. Apache localhost和局域网ip地址访问

    今天忍无可忍重装了公司的电脑,所以把开发工具也都重新装一下. 安装wamp,localhost和局域网ip地址无法访问. 在C:\Windows\System32\drivers\etc\hosts文 ...

  2. Java 通过先序后序序列生成二叉树

    题目 二叉树的前序以及后续序列,以空格间隔每个元素,重构二叉树,最后输出二叉树的三种遍历方式的序列以验证. 输入: 1 2 3 4 5 6 7 8 9 10 3 2 5 4 1 7 8 6 10 9 ...

  3. Oracle 12C 新特性之 sqlplus查看History命令

    12c里,Oracle推出了 History 命令,这很像 Shell 中的 history ,减少了重敲 SQL ,带来了很多便利. 1. 查看history帮助SQL> help histo ...

  4. PreparedStatement/Statement处理insert update等操作时乱码,以及URL

    原文: 在顶目中无意中碰到PreparedStatement 在存DB时出现乱码,困扰了好久终于解决问题 问题代码如下 ps = con.prepareStatement(INSERT_SQL); p ...

  5. CSS3如何实现超出指定文本以省略号显示效果

    不做前端很久了,今天从重构师那里了解到CSS3已经可以实现很多以往必须通过JS才能实现的效果,如渐变,阴影,自动截断文本展示省略号等等强大效果,而且这些功能日渐成熟,已经大量用于生产环境.H5真的日渐 ...

  6. deepin/ubuntu下搭建Jekyll环境

    title: deepin/ubuntu下搭建Jekyll环境 最近用github搭建了个博客,正好也学习一下markdown语法,由于markdown写完后不是立即可见,所以每次写完文章都要经过在线 ...

  7. Regular Expression Matching2015年6月24日

    题目: Implement regular expression matching with support for '.' and '*'. '.' Matches any single chara ...

  8. CodeBlocks

  9. 开关调色新世界BP2888电源解决方案

    LED智能方案经过几年的拼杀,已经风靡照明界.但人们渐渐发现,对照明来说,一味追求花哨的功能并不被市场所认同,而其中开关调色,以其简单易操作的特点,已逐步融入广大消费者的生活习惯中.对吸顶灯,面板灯等 ...

  10. R语言的高质量图形渲染库Cairo(转)

    前言 R语言不仅在统计分析,数据挖掘领域,计算能力强大.在数据可视化上,也不逊于昂贵的商业.当然,背后离不开各种开源软件包的支持,Cairo就是这样一个用于矢量图形处理的类库. Cairo可以创建高质 ...