oracle中schema指的是什么意思
看来有的⼈还是对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为数据库对象的集合,为了区分各个集合,我们需要给这个集合起个名字,这些名字就是我们在企业管理器的⽅案下看到的许多类似⽤户名的节点,这些类似⽤户名的节点其实就是⼀个schema,schema⾥⾯包含了各种对象如tables, views, sequences, stored procedures, synonyms, indexes, clusters, and database links。
⼀个⽤户⼀般对应⼀个schema,该⽤户的schema名等于⽤户名,并作为该⽤户缺省schema。这也就是
我们在企业管理器的⽅案下看到schema名都为数据库⽤户名的原因。Oracle数据库中不能新创建⼀个schema,要想创建⼀个schema,只能通过创建⼀个⽤户的⽅法解决(Oracle中虽然有create schema语句,但是它并不是⽤来创建⼀个schema的),在创建⼀个⽤户的同时为这个⽤户创建⼀个与⽤户名同名的schem并作为该⽤户的缺省shcema。即schema的个数同user的个数相同,⽽且schema 名字同user名字⼀⼀对应并且相同,所有我们可以称schema为user的别名,虽然这样说并不准确,但是更容易理解⼀些。
⼀个⽤户有⼀个缺省的schema,其schema名就等于⽤户名,当然⼀个⽤户还可以使⽤其他的schema。如果我们访问⼀个表时,没有指明该表属于哪⼀个schema中的,系统就会⾃动给我们在表上加上缺省的sheman名。⽐如我们在访问数据库时,访问scott⽤户下的emp表,通过select * from emp; 其实,这sql语句的完整写法为select * p。在数据库中⼀个对象的完整名称为schema.object,⽽不属user.object。类似如果我们在创建对象时不指定该对象的schema,在该对象的schema为⽤户的缺省schema。这就像⼀个⽤户有⼀个缺省的表空间,但是该⽤户还可以使⽤其他的表空间,如果我们在创建对象时不指定表空间,则对象存储在缺省表空间中,要想让对象存储在其他表空间中,我们需要在创建对象时指定该对象的表空间。
咳,说了这么多,给⼤家举个例⼦,否则,⼀切枯燥⽆味!
SQL> Gruant dba to scott
SQL> create table test(name char(10));
Table created.
SQL> create st(name char(10));
Table created.
SQL> insert into test values('scott');
1 row created.
SQL> insert st 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是什么意思
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名。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。