在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了。”---摘自网络

创建数据库表空间的方法:

新建一个Command Window 在提示符下输入一下命令,回车执行就可以了create tablespace dbspace datafile 'D:\oracle\product\10.2.0\oradata\orcl\dbspace.dbf' size 400M autoextend on next 10m maxsize unlimited;--创建表空间DROP TABLESPACE dbspace INCLUDING CONTENTS AND DATAFILES;--删除表空间其中1) DATAFILE: 表空间数据文件存放路径2) SIZE: 起初设置为200M3) UNIFORM: 指定区尺寸为128k,如不指定,区尺寸默认为64k 4) 空间名称histdb 与 数据文件名称 histdb.dbf 不要求相同,可随意命名.5) AUTOEXTEND ON/OFF 表示启动/停止自动扩展表空间6) alter database datafile ' D:\oracle\product\10.2.0\oradata\orcl\histdb.dbf ' resize 500m; //手动修改数据文件大小为下列命令用于为表空间建立用户,将用户的默认表空间设置为刚建立的表空间create user test1 identified by test1 default tablespace dbspace; alter database default tablespace dbspace; create user test identified by test; select username, default_tablespace defspace from dba_users where username='TEST';

以上为本人从网上找的有用的资料,下面是个人对数据库实例、表空间、方案、用户、数据(表等等)的关系理解:

借用上面的很好的例子:一个运行着的数据库程序就是一个实例(电脑上可以运行多个数据库)。实例就像一个大仓库。由于仓库太大,我们租给不同的企业,每个企业根据自身的需求划定仓库的一片区域,这片区域称为表空间。企业允许员工在自己这片区域的仓库的房间内放自己的东西。每位员工只有一个房间,当放上你的一件东西后这个房间就属于你,并且以你的名字自动命名。你就是用户,而房间就是方案(schema)。你可以在你的房间(方案)里置办不同的器具放不同类的东西如:鞋柜、衣橱、床等等(这些对应着表、索引、视图、触发器等等)。你在这些器具里面放的具体的东西比如鞋子、衣服就是数据了。

这只是我个人的理解,我还是菜鸟,理解偏差之处,请各位指出,大家共同学习,共同进步,谢谢O(∩_∩)O~

oracle方案对象有表空间吗,oracle数据库中,实例、表空间、用户、方案、表、数据的关系例子...相关推荐

  1. sqlserver根据字段查表_查找sqlserver数据库中,查询某值所表名和字段名

    有时候我们想通过一个值知道这个值来自数据库的哪个表以及哪个字段,通过一个存储过程实现的.只需要传入一个想要查找的值,即可查询出这个值所在的表和字段名. 前提是要将这个存储过程放在所查询的数据库. CR ...

  2. oracle数据库中批量把一张表里面的数据插入到不同的表中的方法

    oracle数据库中批量把一张表里面的数据插入到不同的表中的方法(insert first into | insert all into) 准备环境 1.oracle数据库自带的scott下的用户表 ...

  3. 现我们数据库中已有的一张新闻表news,结构如下:根据表结构我们创建一个News对象:将下面代码补充完整,完成数据库连接、删除、更新以及查找方法。其中删除方法是通过用户传入新闻id来进行删除。

    现我们数据库中已有的一张新闻表news,结构如下:根据表结构我们创建一个News对象:将下面代码补充完整,完成数据库连接.删除.更新以及查找方法.其中删除方法是通过用户传入新闻id来进行删除 题目 1 ...

  4. mysql数据库中到底能建多少张表?(单实例下单个库)

    单实例mysql数据库中到底能建多少张表? 业务两个同学今天就这个问题过来探讨,他们的诉求是: 1. 一个用户的表要全部放到一个数据库中. 2. 预计1000个用户每个用户初步规划1000张表. 这1 ...

  5. OLE:对象的类没有在注册数据库中注册 问题的三种解决方法

    我在网上下载了破解版的SAS9.3,用了一段时间之后,今天打开就填出一个提示框: OLE:对象的类没有在注册数据库中注册  激活该对象所需的应用程序不可用.是否用"转换--"将其转 ...

  6. mysql表中的多对多关系表_「一对多」关系型数据库中一对多,多对一,多对多关系(详细) - seo实验室...

    一对多 在关系型数据库中,通过外键将表跟表之间联系在了一起. 一个班级有很多学生,外键维护在学生的一方,也就是多的一方.(在做页面设计的时候,需要把两个表连接到一块查询信息) 建立一个student和 ...

  7. java excel 导入 关闭,excel关联别的表格数据库-java实现excel表导入,有的字段数据库中没有,需要关......

    excel中我想用另一张表的内容我数据库,当我在一个... 用VLOOKUP函数,=VLOOKUP(lookup_value,table_array,col_index_num,range_looku ...

  8. linux 写pci配置空间,[转载]应用程序中pci配置空间读写

    应用程序中pci配置空间读写 ~~~~~~~~~~~~~~~~~~~~~~~ 1. 概述 主要讲述在linux操作系统中应用程序如何读写pci配置空间. 2. 基本原理 对于pci设备,由cpu通过一 ...

  9. oracle 数据库ceil,Oracle数据库中ceil函数的操作方案

    以下的内容主要介绍的是Oracle数据库中ceil函数的求比某个数大的最小整数的实际应用的相关介绍,以下就是文章对其的实际的相关操作的具体介绍. 望你浏览完以下的内容会有所收获. SQL>sel ...

  10. oracle10g ora 01841,数据恢复:Oracle数据库中实例恢复起点与终点及RBA

    崔华,网名 dbsnake Oracle ACE Director,ACOUG 核心专家 编辑手记:感谢崔华授权我们独家转载其精品文章,也欢迎大家向"Oracle"社区投稿. 在O ...

最新文章

  1. PTA 基础编程题目集 7-22 龟兔赛跑 C语言
  2. 两点C#的propertyGrid的使用心得
  3. Eureka的高可用
  4. kafka时间轮linux时间轮,Kafka解惑之时间轮 (TimingWheel)
  5. Tip:使用Extender的ResolveControlID事件
  6. python饼状图教程_Python数据可视化:饼状图的实例讲解
  7. 史上最成功的数学预测:用狄拉克方程推导出电子自旋
  8. 在实际项目中应用NHibernate
  9. nginx日志的监控【转】
  10. 淘宝最新签名算法分析(1)
  11. MVVM设计模式《网摘》
  12. 模电_第七章_正弦波振荡电路
  13. Python-集合 字典-set dict fronzenset
  14. python实战笔记之(8):下载知乎视频
  15. 笔记本+显示器常用设置总结
  16. Reprint:大牛讲解信号与系统和数字信号处理;
  17. 面向机密计算的Enclave容器技术栈
  18. HCIE 面试资料-IPv6
  19. 一文带你了解 PPT 里面如何使用合适的图表
  20. 去掉QTableView、QTreeView内item被选中时的虚线框

热门文章

  1. 我的第一篇博客--成长的第一站
  2. 消费者人群画像-信用智能评分(风控模型竞赛经典案例)
  3. android经典项目案例开发
  4. linux双击执行sh脚本
  5. 计算机电源功率高好吗,电脑电源买多大功率适合?实战分析分享
  6. 关于C语言两个小游戏的提示和源码(猜词游戏与控制移动游戏)
  7. 大数据技术基础与应用
  8. 【FinalIK】Full Body Biped IK
  9. apatch zipoutputstream 进行解压缩时提示:不可预料的压缩文件末端
  10. 【G4基础04】2.4 How to Specify Particles