用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
建立表空间语法: 对象
create tablespace db_test
datafile 'D:/oracle/product/10.2.0/userdata/db_test.dbf'
size 50m --表空间初始大小
autoextend on;
查看已经建立好的表空间:
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并非一个对象,oracle也并无提供建立schema的语法。
在oracle中,一个用户就对应一个schema,该用户的schema名等于用户名,并做为该用户缺省schema,用户是不能建立schema的,schema在建立用户的时候建立,并能够指定用户的各类表空间(这点与PostgreSQL是不一样,PostgreSQL是能够建立schema并指派给某个用户)。当前链接到数据库上的用户建立的全部数据库对象默认都属于这个schema(即在不指明schema的状况下)