oracle schema 白话文详解

 

  

概述:sql

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

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

大意:Oracle用户是用链接数据库和访问数据库对象的。(用户是用来链接数据库访问数据库)。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.
大意:模式是数据库对象的集合。模式对象是数据库数据的逻辑结构。(把数据库对象用模式分开成不一样的逻辑结构)。blog

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

 


 

详解:io

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

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

  

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

  即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中详述。比喻到这里,相信你们都清楚了吧。

相关文章
相关标签/搜索