Oracle中数据库实例、表空间、用户、模式的概念及关系

数据库实例

  用Oracle官方描述:实例是访问Oracle数据库所需的一部分计算机内存和辅助处理后台进程,是由进程和这些进程所使用的内存(SGA)所构成一个集合。sql

  咱们访问Oracle都是访问一个实例,但这个实例若是关联了数据库文件,就是能够访问的,若是没有,就会获得实例不可用的错误。数据库

  实例名指的是用于响应某个数据库操做的数据库管理系统的名称。她同时也叫SID。实例名是由参数instance_name决定的。查询当前数据库实例名:oracle

select instance_name from v$instance;

  数据库实例名(instance_name)用于对外部链接。在操做系统中要取得与数据库的联系,必须使用数据库实例名。好比咱们作开发,要链接数据库,就得链接数据库实例名:
性能

jdbc:oracle:thin:@localhost :1521:orcl(orcl就为数据库实例名)spa

  一个数据库能够有多个实例,在做数据库服务集群的时候能够用到。操作系统


数据文件:(待续)


表空间:

   一个数据库由多个表空间组成,一个表空间只能属于一个数据库。.net

   一个表空间能够包含一个或多个数据文件,一个数据文件只能属于一个表空间code

  Oracle数据库是经过表空间来存储物理表的,一个数据库实例能够有N个表空间,一个表空间下能够有N张表。有了数据库,就能够建立表空间。orm

  建立表空间语法: 对象

  1. create tablespace db_test  
    datafile 'D:/oracle/product/10.2.0/userdata/db_test.dbf'  
    size 50m   --表空间初始大小
    autoextend on;  

  查看已经建立好的表空间:  

  1. select default_tablespace, temporary_tablespace, d.username  
    from dba_users d  

  表空间的做用:1.决定数据库实体的空间分配;2.设置数据库用户的空间份额;3.控制数据库部分数据的可用性;4.分布数据于不一样的设备之间以改善性能;5.备份和恢复数据。


用户:

  Oracle数据库建好后,要想在数据库里建表,必须先为数据库创建用户,为用户指定表空间,并为用户授予权限。

       建立用户:

CREATE USER utest  
IDENTIFIED BY utestpwd  
DEFAULT TABLESPACE db_test  
TEMPORARY TABLESPACE temp;  

 有了用户,要想使用用户帐号管理本身的表空间,还得给它分权限:

GRANT CONNECT TO utest;  
GRANT RESOURCE TO utest;  
GRANT dba TO utest;--dba为最高级权限,能够建立数据库,表等。  

  查看数据库用户:

select  * from dba_users;


schema:

  schema是一个逻辑概念,是一个集合,但schema并非一个对象,oracle也并无提供建立schema的语法。

     在oracle中,一个用户就对应一个schema,该用户的schema名等于用户名,并做为该用户缺省schema,用户是不能建立schema的,schema在建立用户的时候建立,并能够指定用户的各类表空间(这点与PostgreSQL是不一样,PostgreSQL是能够建立schema并指派给某个用户)。当前链接到数据库上的用户建立的全部数据库对象默认都属于这个schema(即在不指明schema的状况下)

相关文章
相关标签/搜索