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

最后都变了- 提交于 2019-12-06 13:04:19

数据库实例

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

  我们访问Oracle都是访问一个实例,但这个实例如果关联了数据库文件,就是可以访问的,如果没有,就会得到实例不可用的错误。

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

select instance_name from v$instance;

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

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

  一个数据库可以有多个实例,在作数据库服务集群的时候可以用到。


数据文件:(待续)


表空间:

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

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

  Oracle数据库是通过表空间来存储物理表的,一个数据库实例可以有N个表空间,一个表空间下可以有N张表。有了数据库,就可以创建表空间。

  创建表空间语法: 

  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的情况下)



易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!