oracle用户schema权限,Oracle 用户(user)和模式(schema)的区别

Oracle 用户(user)和模式(schema)的区别

概述:sql

(一)什么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 是一对一的关系。)bash

详解:网络

从官方的定义中,咱们能够看出schema为数据库对象的集合。为了区分各个集合,咱们须要给这个集合起个名字,这些名字就是咱们在企业管理器的方案下看到 的许多相似用户名的节点,这些相似用户名的节点其实就是一个schema。schema里面包含了各类对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。oracle

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

即schema的个数同user的个数相同,并且schema名字同user名字一一 对应而且相同,全部咱们能够称schema为user的别名,虽然这样说并不许确,可是更容易理解一些。spa

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

在数据库中一个对象的完整名称为schema.object,而不属user.object。相似若是咱们在建立对象时不指定该对象 的schema,在该对象的schema为用户的缺省schema。这就像一个用户有一个缺省的表空间,可是该用户还可使用其余的表空间,若是咱们在创 建对象时不指定表空间,则对象存储在缺省表空间中,要想让对象存储在其余表空间中,咱们须要在建立对象时指定该对象的表空间。对象

Oracle常见的各类概念描述

instance是一大坨内存sga,pga....和后台的进程smon pmon.....组成的一个大的应用。

schema就是一个用户和他下面的全部对象。。

tablspace 逻辑上用来放objects.物理上对应磁盘上的数据文件或者裸设备。

Oracle中,结合逻辑存储与物理存储的概念,咱们能够这样来理解数据库、表空间、SCHEMA、数据文件这些概念:

数据库是一个大圈,里面圈着的是表空间,表空间里面是数据文件,那么schema是什么呢?schema是一个逻辑概念,是一个集合,但schema并非一个对象,oracle也并无提供建立schema的语法。进程

schema:

通常而言,一个用户就对应一个schema,该用户的schema名等于用户名,并做为该用户缺省schema,用户是不能建立schema的,schema在建立用户的时候建立,并能够指定用户的各类表空间(这点与PostgreSQL是不一样,PostgreSQL是能够建立schema并指派给某个用户)。当前链接到数据库上的用户建立的全部数据库对象默认都属于这个schema(即在不指明schema的状况下),好比若用户scott链接到数据库,而后create table test(id int not null)建立表,那么这个表被建立在了scott这个schema中;但若这样create kanon.table test(id int not null)的话,这个表被建立在了kanon这个schema中,固然前提是权限容许。

建立用户的方法是这样的:

create user 用户名 identified by 密码

default tablespace 表空间名

temporary tablespace 表空间名

quota 限额 (建议建立的时候指明表空间名)

由此来看,schema是一个逻辑概念。

但必定要注意一点:schema好像并非在建立user时就建立的,而是在该用户建立了第一个对象以后才将schema真正建立的,只有user下存在对象,他对应的schema才会存在,若是user下不存在任何对象了,schema也就不存在了;

数据库:

在oracle中,数据库是由表空间来组成的,而表空间里面是具体的物理文件---数据文件。咱们能够建立数据库并为其指定各类表空间。

表空间:

这是个逻辑概念,本质上是一个或者多个数据文件的集合。

数据文件:

具体存储数据的物理文件,是一个物理概念。

一个数据文件只能属于一个表空间,一个表空间能够包含一个或多个数据文件。一个数据库由多个表空间组成,一个表空间只能属于一个数据库。

若还不理解,下面是我从网上摘的一个比喻,很形象的解释了什么是Database,什么是Schema,什么是Table,什么是列,什么是行,什么是User,不妨一看。

“咱们能够把Database看做是一个大仓库,仓库分了不少不少的房间,Schema就是其中的房间,一个Schema表明一个房间,Table能够看做是每一个Schema中的床,Table(床)被放入每一个房间中,不能放置在房间以外,那岂不是晚上睡觉无家可归了,而后床上能够放置不少物品,就比如 Table上能够放置不少列和行同样,数据库中存储数据的基本单元是Table,现实中每一个仓库放置物品的基本单位就是床, User就是每一个Schema的主人,(因此Schema包含的是Object,而不是User),user和schema是一一对应的,每一个user在没有特别指定下只能使用本身schema(房间)的东西,若是一个user想使用其余schema(房间)的东西,那就要看那个schema(房间)的user(主人)有没有给你这个权限了,或者看这个仓库的老大(DBA)有没有给你这个权限了。换句话说,若是你是某个仓库的主人,那么这个仓库的使用权和仓库中的全部东西都是你的(包括房间),你有彻底的操做权,能够扔掉不用的东西从每一个房间,也能够放置一些有用的东西到某一个房间,你还能够给每一个User分配具体的权限,也就是他到某一个房间能作些什么,是只能看(Read-Only),仍是能够像主人同样有全部的控制权(R/W),这个就要看这个User所对应的角色Role了。”---摘自网络

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值