• 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为数据库对象的集合,为了区分各个集合,我们须要给这个集合起个名字,这些名字就是我们在企业管理器的方案下看到的很多相似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名字。

  • 相关阅读:
    Android基础知识
    使用Android Studio和Genymotion模拟器搭建Andriod开发环境
    【原】Java开发环境搭建
    【转】JavaScript顶级对象参考模型
    【转】在.Net中关于AOP的实现
    【转】各版本IIS下ASP.net请求处理过程区别
    【转】我们应该如何去了解JavaScript引擎的工作原理
    Linux系统编程(27)——线程控制
    Linux系统编程(26)——守护进程
    Linux系统编程(25)——终端
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4570254.html
Copyright © 2020-2023  润新知