博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle中schema指的是什么?
阅读量:5102 次
发布时间:2019-06-13

本文共 2174 字,大约阅读时间需要 7 分钟。

看来有的人还是对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.
A user is a name defined in the database that can connect to and access objects.
Schemas and users help database administrators manage database security.
从定义中我们能够看出schema为数据库对象的集合,为了区分各个集合,我们须要给这个集合起个名字,这些名字就是我们在企业管理器的方案下看到的很多相似username的节点,这些相似username的节点事实上就是一个schema,schema里面包括了各种对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。
一个用户一般相应一个schema,该用户的schema名等于username,并作为该用户缺省schema。这也就是我们在企业管理器的方案下看到schema名都为数据库username的原因。Oracle数据库中不能新创建一个schema,要想创建一个schema,仅仅能通过创建一个用户的方法解决(Oracle中尽管有create schema语句,可是它并非用来创建一个schema的),在创建一个用户的同一时候为这个用户创建一个与username同名的schem并作为该用户的缺省shcema。即schema的个数同user的个数同样,并且schema名字同user名字一一 相应并且同样,全部我们能够称schema为user的别名,尽管这样说并不准确,可是更easy理解一些。
一个用户有一个缺省的schema,其schema名就等于username,当然一个用户还能够使用其它的schema。假设我们訪问一个表时,没有指明该表属于哪一个schema中的,系统就会自己主动给我们在表上加上缺省的sheman名。比方我们在訪问数据库时,訪问scott用户下的emp表,通过select * from emp; 事实上,这sql语句的完整写法为select * from scott.emp。在数据库中一个对象的完整名称为schema.object,而不属user.object。相似假设我们在创建对象时不指定该对象的schema,在该对象的schema为用户的缺省schema。这就像一个用户有一个缺省的表空间,可是该用户还能够使用其它的表空间,假设我们在创建对象时不指定表空间,则对象存储在缺省表空间中,要想让对象存储在其它表空间中,我们须要在创建对象时指定该对象的表空间。
咳,说了这么多,给大家举个样例,否则,一切枯燥无味!
SQL> Gruant dba to scott
SQL> create table test(name char(10));
Table created.
SQL> create table system.test(name char(10));
Table created.
SQL> insert into test values('scott');
1 row created.
SQL> insert into system.test values('system');
1 row created.
SQL> commit;
Commit complete.
SQL> conn system/manager
Connected.
SQL> select * from test;
NAME
----------
system
SQL> ALTER SESSION SET CURRENT_SCHEMA = scott; --改变用户缺省schema名
Session altered.
SQL> select * from test;
NAME
----------
scott
SQL> select owner ,table_name from dba_tables where table_name=upper('test');
OWNER TABLE_NAME
------------------------------ ------------------------------
SCOTT TEST
SYSTEM TEST
--上面这个查询就是我说将schema作为user的别名的根据。实际上在使用上,shcema与user全然一样,没有什么差别,在出现schema名的地方也能够出现user名。

转载于:https://www.cnblogs.com/bhlsheji/p/4022111.html

你可能感兴趣的文章
centos 7 redis-4.0.11 主从
查看>>
Java的基本数据类型与转换
查看>>
蓝桥练习 之 单词个数统计
查看>>
[原创]独立模式安装Hive
查看>>
bzoj1088 [SCOI2005]扫雷Mine
查看>>
BZOJ【1606】购买干草
查看>>
树套树小结
查看>>
Spring切入点表达式常用写法
查看>>
博弈论 从懵逼到入门 详解
查看>>
csu 1577 Dice Game (博弈)
查看>>
线性表的顺序表示和实现
查看>>
【PMP】项目整合管理
查看>>
AndroidStudio中获得的VersionCode一直为1和VersionName一直为1.0
查看>>
【搜索引擎基础知识1】搜索引擎基本架构 2014-05-23 16:00 568人阅读 评论(0) 收藏...
查看>>
POJ1144 Network 连通性
查看>>
shell脚本中的日期处理
查看>>
HDU 1754 I Hate It
查看>>
【python】-- Django ModelForm
查看>>
响应式网页设计
查看>>
self-hacking第五天
查看>>