今天重读ORACLE官方文档《concepts》读到schema的基本概念对它的理解更进一层官方文档中关于schema是这样解释的
A schema is a collection of database objects A schema is owned by a database user and has the same name as that user Schema objects are the logical structures that directly refer to the databases data Schema objects include structures like tables views and indexes(There is no relationship between a tablespace and a schema Objects in the same schema can be in different tablespaces and a tablespace can hold objects from different schemas)
官方文档里面说得比较明白schema是数据对象的集合包括像表视图索引同义词等等都可以说是schema的对象但不够生动网上有篇文章里面把schema和user的关系用一个形象的比喻阐述得非常透彻引用如下
user即Oracle中的用户和所有系统的中用户概念类似用户所持有的是系统的权限及资源而schema所涵盖的是各种对象它包含了表函数包等等对象的所在地并不包括对他们的权限控制好比一个房子里面放满了家具对这些家具有支配权的是房子的主人(user)而不是房子(schema)你可以也是一个房子的主人(user)拥有自己的房子(schema)可以通过alter session的方式进入别人的房子如果你没有特别指定的话你所做的操作都是针对你当前所在房子中的东西至于你是否有权限使用(select)搬动(update)或者拿走(delete)这些家具就看这个房子的主人有没有给你这样的权限了或者你是整个大厦(DB)的老大(DBA)alter session set schema可以用来代替synonyms如果你想调用其他schema的对象(有权限的前提下)但并没有建synonym同时又不想把其他 schema名字放入代码中就可以首先使用alter session set schema=<其他schema名字>
这段文字说得非常生动把user和schema的区别阐述得很透彻下面通过具体的例子来加深对user和schema两者区别的认识
第一步以sys用户登陆SQL并建立普通用户storm和penguin
$ sqlplus / as sysdba
SQL> create user storm identified by storm;
User created
SQL> create user penguin identified by penguin;
User created
第二步赋予一些基本的权限给新建的用户storm和penguin
SQL> grant connectcreate tableresource to stormpenguin;
Grant succeeded
第三步以storm用户登陆创建一张表并插入数据
SQL> conn storm/storm
Connected
SQL> create table t (id int);
Table created
SQL> insert into t values();
row created
SQL> commit;
Commit complete
第四步以penguin用户登陆看能否查询storm用户所建表里面的数据
SQL> conn penguin/penguin
Connected
SQL> select table_name from user_tables;
no rows selected
SQL> show user;
USER is PENGUIN
SQL> select * from stormt;
select * from stormt
*
ERROR at line :
ORA: table or view does not exist
从以上结果可以看出用户 penguin无法查看用户storm所建表里面的内容甚至被告知没有这张表
第五步修改当前schema为storm并继续查询
SQL> alter session set current_schema=storm;
Session altered
SQL> show user;
USER is PENGUIN
SQL> select * from stormt;
select * from stormt
*
ERROR at line :
ORA: table or view does not exist
仍然不能查看
第六步以storm用户登陆赋予penguin用户查看t表的权限
SQL> conn storm/storm
Connected
SQL> grant select on t to penguin;
Grant succeeded
第七步以penguin用户登陆查看storm用户的t表
SQL> conn penguin/penguin
Connected
SQL> select * from stormt;
ID
更简单的将当前schema更改为storm可以简化查询过程
SQL> alter session set current_schema=storm;
Session altered
SQL> select * from t;
ID
这个实验下来对user和schema的区别和联系应该有了进一步的理解了