概述:

(一)什么Oracle叫用户(user):

  A user is a name defined in the database that can connect to and access objects.

大意:Oracle用户是用连接数据库和访问数据库对象的。(用户是用来连接数据库访问数据库)。

(二)什么叫模式(schema):

  A schema is a collection of database objects (used by a user.). Schema objects are the logical structures that directly refer to the database’s data.
大意:模式是数据库对象的集合。模式对象是数据库数据的逻辑结构。(把数据库对象用模式分开成不同的逻辑结构)。

(三)用户(user)与模式(schema)的区别:
  Schemas and users help database administrators manage database security.
大意:用户是用来连接数据库对象。而模式用是用创建管理对象的。(模式跟用户在oracle 是一对一的关系。)


详解:

  从官方的定义中,我们可以看出schema为数据库对象的集合。为了区分各个集合,我们需要给这个集合起个名字,这些名字就是我们在企业管理器的方案下看到 的许多类似用户名的节点,这些类似用户名的节点其实就是一个schema。

  schema里面包含了各种对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。

  

  一个用户一般对应一个schema,该用户的schema名等于用户名,并作为该用户缺省schema。这也就是我们在企业管理器的方案下看 到schema名都为数据库用户名的原因。而Oracle数据库中不能新创建一个schema,要想创建一个schema,只能通过创建一个用户的方法解决 (Oracle中虽然有create schema语句,但是它并不是用来创建一个schema的),在创建一个用户的同时为这个用户创建一个与用户名同名的schem并作为该用户的缺省 shcema。

  即schema的个数同user的个数相同,而且schema名字同user名字一一 对应并且相同,所有我们可以称schema为user的别名,虽然这样说并不准确,但是更容易理解一些。

  一个用户有一个缺省的schema,其schema名就等于用户名,当然一个用户还可以使用其他的schema。如果我们访问一个表时,没有指明该 表属于哪一个schema中的,系统就会自动给我们在表上加上缺省的sheman名。比如我们在访问数据库时,访问scott用户下的emp表,通过 select * from emp; 其实,这sql语句的完整写法为select * from scott.emp。

  在数据库中一个对象的完整名称为schema.object,而不属user.object。类似如果我们在创建对象时不指定该对象 的schema,在该对象的schema为用户的缺省schema。这就像一个用户有一个缺省的表空间,但是该用户还可以使用其他的表空间,如果我们在创 建对象时不指定表空间,则对象存储在缺省表空间中,要想让对象存储在其他表空间中,我们需要在创建对象时指定该对象的表空间。

1个数据库下,可以有多个模式。

1个模式下,可以有0个或多个表 。

首先我来做一个比喻,什么是Database,什么是Schema,什么是Table,什么是Column,什么是Row,什么是User?我们可以把Database看作是一个大仓库,仓库分了很多很

多的房间,Schema就是其中的房间,一个Schema代表一个房间,Table可以看作是每个Schema中的床,Table(床)就被放入每个房间中,不能放置在房间之外,那岂不是晚上睡

觉无家可归了J。,然后床上可以放置很多物品,就好比Table上可以放置很多列和行一样,数据库中存储数据的基本单元是Table,现实中每个仓库放置物品的基本单位就是床,

User就是每个Schema的主人,【所以Schema包含的是Object,而不是User】,其实User是对应于数据库的(即User是每个对应数据库的主人),既然有操作数据库(仓库)的权

利,就肯定有操作数据库中每个Schema(房间)的权利,就是说每个数据库映射的User有每个Schema(房间)的钥匙,换句话说,如果他是某个仓库的主人,那么这个仓库的使

用权和仓库中的所有东西都是他的(包括房间),他有完全的操作权,可以扔掉不用的东西从每个房间,也可以放置一些有用的东西到某一个房间,当然也可以拆除一个房间

(Remove Schema)。呵呵,和现实也太相似了吧。我(仓库的管理员)还可以给User分配具体的权限,也就是他到某一个房间能做些什么,是只能看(Read-Only),还是可以

像主人一样有所有的控制权(R/W),这个就要看这个User所对应的角色Role了,至于分配权限的问题,我留在以后单独的blog中详述。比喻到这里,相信大家都清楚了吧。

最新文章

  1. .NET面试题系列[9] - IEnumerable
  2. jquey知识点整理
  3. Alpha阶段冲刺总结
  4. 一个不陌生的JS效果-marquee,用css3来实现
  5. 【转载国外好文】代工开发一个iOS应用没有那么容易
  6. OS X Framework Library not loaded: 'Image not found'的解决办法
  7. linux命令每日一练习-rmdir mv
  8. machine learning----->学习成绩
  9. Struts2部署在Websphere上的问题
  10. config、make、make install
  11. TCP/IP 协议大致的概念
  12. 用Spring3编写第一个HelloWorld项目
  13. HDU 5818 Joint Stacks(左偏树)
  14. 【 D3.js 进阶系列 — 2.1 】 力学图的事件 + 顶点的固定
  15. ES6之Promise
  16. C#中的泛型化方法的实现
  17. name 'reload' is not defined解决方法
  18. 多人合作项目如何去管理git仓库
  19. MATLAB EMD 初始
  20. Python:每日一题002

热门文章

  1. django url 使用总结
  2. Intel DAAL AI加速——神经网络
  3. html <frame>标签使用
  4. SQL*Loader 详解
  5. POJ 2566 Bound Found 尺取 难度:1
  6. php通过$_SERVER['HTTP_USER_AGENT']获取浏览器useAgent
  7. 在 Ubuntu 14.04 Chrome中安装Flash Player(转)
  8. java生成db文件
  9. 逆向路由器固件之SQL注入 Part3
  10. 如何把dos命令窗口里的字符复制下来?